api.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. import {
  2. baseUrl,
  3. baseApiUrl
  4. } from './config.js';
  5. import * as common from './common.js' //引入common
  6. import * as db from './db.js' //引入common
  7. // 需要登陆的,都写到这里,否则就是不需要登陆的接口
  8. let methodsToken = [];
  9. const post = (method, data, callback, type, orgurl) => {
  10. let userToken = '';
  11. let auth = '';
  12. // 判断token是否存在
  13. console.log("method: ", method);
  14. if (methodsToken.indexOf(method) >= 0) {
  15. // 获取用户token
  16. let auth = db.get("auth");
  17. console.log(auth);
  18. let nowdate = (new Date()) / 1000; //当前时间戳
  19. //新增用户判断是否登录逻辑begin
  20. common.isLogin();
  21. //新增用户判断是否登录逻辑end
  22. if (!auth || auth.createtime + auth.expires_in < nowdate) {
  23. common.toLogin();
  24. return false;
  25. } else {
  26. userToken = auth.token;
  27. }
  28. }
  29. if (type) {
  30. method = type + '/' + method
  31. } else {
  32. method = '/' + method
  33. }
  34. let realurl = baseApiUrl + method;
  35. if (orgurl) {
  36. realurl = baseUrl + orgurl;
  37. }
  38. uni.showLoading({
  39. title: '',
  40. icon: 'loading'
  41. });
  42. uni.request({
  43. url: realurl,
  44. data: data,
  45. sslVerify: false,
  46. header: {
  47. 'Accept': 'application/json',
  48. 'Content-Type': 'application/x-www-form-urlencoded',
  49. 'token': userToken,
  50. '__token__': userToken
  51. },
  52. method: 'POST',
  53. success: (response) => {
  54. uni.hideLoading();
  55. const result = response.data
  56. if (result.msg == 'Please login' || result.msg == '请登陆') {
  57. db.del("user");
  58. db.del("auth");
  59. console.log('未登陆')
  60. uni.showToast({
  61. title: result.msg,
  62. icon: 'none',
  63. duration: 2000,
  64. complete: function() {
  65. uni.reLaunch({
  66. url: '/pages/index/index',
  67. })
  68. }
  69. });
  70. }
  71. callback(result);
  72. },
  73. fail: (error) => {
  74. console.log(error, "error")
  75. uni.hideLoading();
  76. if (error && error.response) {
  77. showError(error.response);
  78. }
  79. },
  80. });
  81. }
  82. // 上传图片
  83. export const uploadImage = (method, data = {}, callback, num = 9, type) => {
  84. if (type) {
  85. method = type + '/' + method
  86. } else {
  87. method = method
  88. }
  89. let userToken = '';
  90. let auth = db.get("auth");
  91. userToken = auth.token;
  92. uni.chooseImage({
  93. count: num,
  94. success: (res) => {
  95. uni.showLoading({
  96. title: '上传中...'
  97. });
  98. let tempFilePaths = res.tempFilePaths
  99. for (var i = 0; i < tempFilePaths.length; i++) {
  100. data.file = tempFilePaths[i]
  101. uni.uploadFile({
  102. url: baseApiUrl + method,
  103. filePath: tempFilePaths[i],
  104. fileType: 'image',
  105. name: 'file',
  106. headers: {
  107. 'Accept': 'application/json',
  108. 'Content-Type': 'multipart/form-data',
  109. 'token': userToken
  110. },
  111. formData: data,
  112. success: (uploadFileRes) => {
  113. callback(JSON.parse(uploadFileRes.data))
  114. },
  115. fail: (error) => {
  116. if (error && error.response) {
  117. common.showError(error.response);
  118. }
  119. },
  120. complete: () => {
  121. setTimeout(function() {
  122. uni.hideLoading();
  123. }, 250);
  124. },
  125. });
  126. }
  127. }
  128. });
  129. }
  130. const get = (url, callback) => {
  131. uni.showLoading({
  132. title: '加载中'
  133. });
  134. let realurl = baseUrl + url;
  135. if (url.indexOf('http:') >= 0 || url.indexOf('https:') >= 0) {
  136. let realurl = url;
  137. }
  138. uni.request({
  139. url: realurl,
  140. header: {
  141. 'Accept': 'application/json',
  142. 'Content-Type': 'application/x-www-form-urlencoded', //自定义请求头信息
  143. },
  144. method: 'GET',
  145. success: (response) => {
  146. callback(response.data);
  147. },
  148. fail: (error) => {
  149. if (error && error.response) {
  150. showError(error.response);
  151. }
  152. },
  153. complete: () => {
  154. setTimeout(function() {
  155. uni.hideLoading();
  156. }, 250);
  157. }
  158. });
  159. }
  160. const showError = error => {
  161. let errorMsg = ''
  162. switch (error.status) {
  163. case 400:
  164. errorMsg = '请求参数错误'
  165. break
  166. case 401:
  167. errorMsg = '未授权,请登录'
  168. break
  169. case 403:
  170. errorMsg = '跨域拒绝访问'
  171. break
  172. case 404:
  173. errorMsg = `请求地址出错: ${error.config.url}`
  174. break
  175. case 408:
  176. errorMsg = '请求超时'
  177. break
  178. case 500:
  179. errorMsg = '服务器内部错误'
  180. break
  181. case 501:
  182. errorMsg = '服务未实现'
  183. break
  184. case 502:
  185. errorMsg = '网关错误'
  186. break
  187. case 503:
  188. errorMsg = '服务不可用'
  189. break
  190. case 504:
  191. errorMsg = '网关超时'
  192. break
  193. case 505:
  194. errorMsg = 'HTTP版本不受支持'
  195. break
  196. default:
  197. errorMsg = error.msg
  198. break
  199. }
  200. uni.showToast({
  201. title: errorMsg,
  202. icon: 'none',
  203. duration: 2000
  204. });
  205. }
  206. const syncget = (url, data) => {
  207. return new Promise(function(resolve, reject) {
  208. get(url + queryParams(data, true), (result) => {
  209. try {
  210. resolve(result);
  211. } catch (e) {
  212. reject(e);
  213. }
  214. })
  215. })
  216. }
  217. const syncpost = (f, m, d) => {
  218. return new Promise(function(resolve, reject) {
  219. post(f, d, (result) => {
  220. try {
  221. resolve(result);
  222. } catch (e) {
  223. reject(e);
  224. }
  225. }, m, m);
  226. })
  227. }
  228. // 登录
  229. export const third = (data, callback) => post('third', data, callback, 'discover/User');
  230. // 用户绑定手机
  231. export const bindphone = (data, callback) => post('bind', data, callback, 'discover/User');
  232. // 修改用户信息
  233. export const profile = (data, callback) => post('profile', data, callback, 'discover/User');
  234. // 发送验证码
  235. export const sendSmsVerify = (data, callback) => post('sendSmsVerify', data, callback, 'discover/User');
  236. // 注册
  237. export const register = (data, callback) => post('register', data, callback, 'discover/User');
  238. // 登录
  239. export const login = (data, callback) => post('login', data, callback, 'discover/User');
  240. // 退出登录
  241. export const logout = (data, callback) => post('logout', data, callback, 'discover/User');
  242. function queryParams(data = {}, isPrefix = true, arrayFormat = 'brackets') {
  243. let prefix = isPrefix ? '?' : ''
  244. let _result = []
  245. if (['indices', 'brackets', 'repeat', 'comma'].indexOf(arrayFormat) == -1) arrayFormat = 'brackets';
  246. for (let key in data) {
  247. let value = data[key]
  248. // 去掉为空的参数
  249. if (['', undefined, null].indexOf(value) >= 0) {
  250. continue;
  251. }
  252. if (value.length > 0) {
  253. value = value.replace(/%/g, "%25");
  254. value = value.replace(/\&/g, "%26");
  255. value = value.replace(/\+/g, "%2B");
  256. }
  257. // 如果值为数组,另行处理
  258. if (value.constructor === Array) {
  259. // e.g. {ids: [1, 2, 3]}
  260. switch (arrayFormat) {
  261. case 'indices':
  262. // 结果: ids[0]=1&ids[1]=2&ids[2]=3
  263. for (let i = 0; i < value.length; i++) {
  264. _result.push(key + '[' + i + ']=' + value[i])
  265. }
  266. break;
  267. case 'brackets':
  268. // 结果: ids[]=1&ids[]=2&ids[]=3
  269. value.forEach(_value => {
  270. _result.push(key + '[]=' + _value)
  271. })
  272. break;
  273. case 'repeat':
  274. // 结果: ids=1&ids=2&ids=3
  275. value.forEach(_value => {
  276. _result.push(key + '=' + _value)
  277. })
  278. break;
  279. case 'comma':
  280. // 结果: ids=1,2,3
  281. let commaStr = "";
  282. value.forEach(_value => {
  283. commaStr += (commaStr ? "," : "") + _value;
  284. })
  285. _result.push(key + '=' + commaStr)
  286. break;
  287. default:
  288. value.forEach(_value => {
  289. _result.push(key + '[]=' + _value)
  290. })
  291. }
  292. } else {
  293. _result.push(key + '=' + value)
  294. }
  295. }
  296. return _result.length ? prefix + _result.join('&') : ''
  297. }
  298. // 首页功能集
  299. export const getIndexFunction = (data, callback) => get('api/minnansoul/banner_function/getIndexFunction' + queryParams(
  300. data,
  301. true), callback);
  302. // 城市主体列表
  303. export const getCity = (data, callback) => get('api/minnansoul/main_body/getCity' + queryParams(data, true),
  304. callback);
  305. // 模型的主体栏目列表
  306. export const getColumnList = (data, callback) => post('getColumnList', data, callback,
  307. 'minnansoul/main_body_column');
  308. // 模型内容列表
  309. export const getContentList = (data, callback) => post('getContentList', data, callback,
  310. 'minnansoul/content');
  311. // 内容详情
  312. export const getContentDetails = (data, callback) => post('getContentDetail', data, callback,
  313. 'minnansoul/content');
  314. // 模型主体栏目内容列表
  315. export const getMainBodyColumnContentList = (data, callback) => post('getMainBodyColumnContentList', data, callback,
  316. 'minnansoul/content');
  317. // 课程界面数据
  318. export const getCourseList = (data, callback) => post('getCourseList', data, callback, '',
  319. 'addons/yuneducation/course/getCourseList');