App.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. <script>
  2. import config from '@/util/url.js';
  3. export default {
  4. globalData: {
  5. token: "",
  6. // 文本消息
  7. socketTask: null,
  8. // urlData: "wss://www.toreskj.com/api/api_gateway?method=control_center.real_time.im_message",
  9. urlData: config.wsUrl + "/api/api_gateway?method=control_center.real_time.im_message",
  10. is_open_socket: false, // 确保websocket是打开状态
  11. list: [],
  12. userId: null, // 用户ID
  13. // 即构
  14. video: null, //房间密码和token
  15. // 测试 - 心跳检测
  16. status: null, // websocket是否关闭
  17. lockReconnect: false, // 避免重复连接
  18. // timeout: 5000, // 多少秒执行监测
  19. timeout: 10000, // 多少秒执行监测
  20. timeoutObj: null, // 检测服务器端是否还活着
  21. reconnectTimeOutObj: null, // 重连之后多久再次重连
  22. // 测试
  23. app: [],
  24. // 消息发送加载
  25. msgSetTime: null,
  26. g_wakelock: null
  27. },
  28. onLoad() {
  29. },
  30. onLaunch: function() {
  31. console.log('启动了')
  32. // App启动
  33. var that = this
  34. // #ifdef APP-PLUS
  35. this.wakeLock()
  36. // #endif
  37. // uni.getStorage({
  38. // key: 'session_key',
  39. // success: function(res) {
  40. // that.globalData.token = res.data
  41. // // console.log('登录成功了')
  42. // that.msgInit(); // 文本初始化
  43. // },
  44. // fail: function(err) {
  45. // console.log(err)
  46. // console.log('没有登录成功')
  47. // }
  48. // })
  49. },
  50. onShow: function() {
  51. var that = this
  52. this.$store.dispatch('updateTaskRecordRatio')
  53. // App展示在前台
  54. console.log('+++++++++++++++++++App Show-------------------------------------')
  55. // this.msgInit(); // 再进行请求
  56. uni.getStorage({
  57. key: 'session_key',
  58. success: function(res) {
  59. that.globalData.token = res.data
  60. // console.log('登录成功了')
  61. console.log(res)
  62. // that.msgInit(); // 文本初始化
  63. },
  64. fail: function(err) {
  65. console.log(err)
  66. console.log('没有登录成功')
  67. }
  68. })
  69. },
  70. onHide: function() {
  71. // App不再再展示在前台
  72. this.close(); // 关闭
  73. },
  74. methods: {
  75. // 实时通信 - 初始化
  76. msgInit() {
  77. console.log('进入了实时通信初始化=--------------------------', this.globalData.token)
  78. var that = this
  79. // 连接webscoket
  80. that.globalData.socketTask = uni.connectSocket({
  81. url: this.globalData.urlData + "&token=" + that.globalData.token,
  82. success(data) {
  83. // console.log("websocket连接中");
  84. }
  85. });
  86. // 发送消息 - 获取对话列表
  87. var obj = {
  88. 'action': 'list', // 动作标识,必填
  89. 'recv_user_id': '', // 接收人用户id, 非必填
  90. 'data': {}
  91. }
  92. that.globalData.socketTask.onOpen((res) => {
  93. console.log('websocket开启了')
  94. // 清除重连定时器
  95. // clearTimeout(that.globalData.reconnectTimeOutObj)
  96. // that.notReconnect()
  97. that.globalData.socketTask.send({
  98. data: JSON.stringify(obj),
  99. async success(res) {
  100. that.globalData.is_open_socket = true
  101. console.log("消息发送成功");
  102. uni.hideLoading(); // 关闭通信异常弹框
  103. },
  104. });
  105. that.start() // 开启心跳机制
  106. })
  107. // // 接收服务器返回的消息
  108. // // 注:只有连接正常打开中 ,才能正常收到消息
  109. that.globalData.socketTask.onMessage((res) => {
  110. // console.log("收到服务器内容:");
  111. var val = JSON.parse(res.data)
  112. console.warn('这是返回的内容---------', val)
  113. if (val.action == 'list') {
  114. clearTimeout(that.globalData.msgSetTime); // 消息发送成功,清除发送失败定时器
  115. console.log('这是发送人的ID', that.globalData.userId)
  116. var obj1 = {
  117. 'action': 'list', // 动作标识,必填
  118. 'recv_user_id': that.globalData.userId, // 接收人用户id, 非必填
  119. 'data': {
  120. 'msg_status': false, // 消息未读
  121. 'msg_info': '', // 发送消息
  122. }
  123. }
  124. that.globalData.socketTask.send({
  125. data: JSON.stringify(obj1),
  126. async success(res) {},
  127. });
  128. that.globalData.userId = null
  129. } else if (val.action == 'none') {
  130. console.log('进入了none', val)
  131. that.globalData.list = val.data
  132. // this.$store.state.list = val.data
  133. this.$store.commit('updateMessageList', val.data)
  134. } else if (val.action == 'recv_video') {
  135. console.warn('recv_video---------------- 1', val.data)
  136. if (this.$store.state.isVideoCallRefused) {
  137. this.$store.commit('updateIsRefusedCall', false)
  138. return
  139. }
  140. // this.$store.state.video = val.data
  141. this.$store.commit('updateIsRefusedCall', false)
  142. if (this.$store.state.isVideoTalking) {
  143. // 占线中
  144. var obj = {
  145. 'action': 'occupy', // 动作标识,必填
  146. 'recv_user_id': val.data.user_id, // 接收人用户id, 非必填
  147. 'data': {}
  148. }
  149. this.globalData.socketTask.send({
  150. data: JSON.stringify(obj),
  151. async success(res) {
  152. console.warn('占线消息发送成功1111', val.data)
  153. }
  154. });
  155. return
  156. }
  157. that.globalData.video = val.data
  158. uni.switchTab({
  159. url: '/pages/response/index',
  160. success(res) {
  161. console.warn(res, '-------------- into room ')
  162. },
  163. fail(err) {
  164. console.error(err)
  165. },
  166. complete() {
  167. console.warn('-------------- into room complete')
  168. }
  169. })
  170. this.$store.commit('updateVideoInfo', val.data)
  171. setTimeout(() => {
  172. console.log('跳转了')
  173. this.$store.getters.watchData;
  174. }, 1500)
  175. } else if (val.action == 'send_video_rsp') {
  176. console.warn('recv_video---------------- response', val.data)
  177. if (this.$store.state.isVideoCallRefused) {
  178. this.$store.commit('updateIsRefusedCall', false)
  179. return
  180. }
  181. this.$store.commit('updateIsRefusedCall', false)
  182. // if(this.)
  183. this.$store.commit('updateVideoSelfRoomInfo', val.data)
  184. console.warn('into romm ready ------------------', this.roomInfo)
  185. console.warn('into romm ------------------', this.roomInfo)
  186. this.$store.commit('updateTalkingStatus', true)
  187. uni.navigateTo({
  188. url: '/pages/response/video?videoObj=' + JSON.stringify(val.data),
  189. success(res) {
  190. console.warn(res, '-------------- into room ')
  191. },
  192. fail(err) {
  193. console.error(err)
  194. },
  195. complete() {
  196. console.warn('-------------- into room complete')
  197. }
  198. })
  199. } else if (val.action == 'reject_video_rsp') {
  200. // 被拒绝后挂断视频通话
  201. this.$store.commit('updateIsRefusedCall', true)
  202. } else if (val.action == 'occupy_rsp') {
  203. console.warn('----------------------- is refused')
  204. // 占线中,挂断发起通话
  205. this.$store.commit('updateIsRefusedCall', true)
  206. } else if (val.action == 'ok') {
  207. this.start(); // 心跳机制
  208. } else if (val.action == 'error') {
  209. if (val.data.errorCode == 403) {
  210. uni.setStorageSync('session_key', '')
  211. uni.$u.totast('用户在其他地方登陆,请重新登陆')
  212. this.close();
  213. setTimeout(() => {
  214. uni.navigateTo({
  215. url: "/pages/login/login"
  216. })
  217. }, 2000)
  218. }
  219. }
  220. // this.reset();
  221. // console.log('消息可正常接收');
  222. });
  223. // 连接断开
  224. // 如果希望websocket连接一直保持,在close或者error上绑定重新连接方法。
  225. this.globalData.socketTask.onClose((res) => {
  226. console.warn(res, '连接关闭');
  227. clearTimeout(this.globalData.timeoutObj);
  228. setTimeout(() => {
  229. that.reconnect();
  230. }, 5000)
  231. })
  232. // 连接失败
  233. that.globalData.socketTask.onError((res) => {
  234. console.log(res, '连接错误');
  235. uni.showLoading({
  236. title: "通信异常,连接中..."
  237. })
  238. clearTimeout(this.globalData.timeoutObj);
  239. setTimeout(() => {
  240. that.reconnect();
  241. }, 5000)
  242. })
  243. },
  244. // 心跳机制
  245. start() {
  246. var that = this
  247. this.globalData.timeoutObj = setTimeout(() => {
  248. //这里发送一个心跳,后端收到后,返回一个心跳消息,
  249. //onmessage拿到返回的心跳就说明连接正常
  250. var obj = {
  251. 'action': 'keepalive', // 动作标识,必填
  252. 'type': 'App',
  253. 'recv_user_id': '', // 接收人用户id, 非必填
  254. 'data': {
  255. msg_status: false,
  256. msg_info: "",
  257. }
  258. }
  259. that.globalData.socketTask.send({
  260. data: JSON.stringify(obj),
  261. async success(res) {
  262. that.globalData.is_open_socket = true
  263. // console.log('消息发送成功1111')
  264. }
  265. });
  266. console.log('进入心跳机制了', that.globalData.socketTask)
  267. let ws_temp = null
  268. ws_temp = that.globalData.socketTask
  269. that.globalData.socketTask = ws_temp
  270. ws_temp = null
  271. }, this.globalData.timeout)
  272. },
  273. // 清除心跳机制
  274. reset() {
  275. // 清除定时器重新发送一个心跳信息
  276. // clearTimeout(this.globalData.timeoutObj);
  277. clearTimeout(this.globalData.timeoutObj);
  278. this.start();
  279. },
  280. // 重连
  281. reconnect() {
  282. // 防止多个方法调用,多处重连
  283. if (this.lockReconnect) {
  284. return;
  285. };
  286. this.lockReconnect = true;
  287. console.log('准备重连');
  288. //没连接上会一直重连,设置延迟避免请求过多
  289. this.globalData.reconnectTimeOutObj = setTimeout(() => {
  290. // 重新连接
  291. this.msgInit()
  292. console.log('正在重新连接')
  293. this.lockReconnect = false;
  294. }, 4000);
  295. },
  296. // 清除重连
  297. notReconnect() {
  298. clearTimeout(this.globalData.reconnectTimeOutObj)
  299. },
  300. // 手动关闭
  301. close() {
  302. var that = this
  303. console.log('已经手动关闭了')
  304. that.globalData.socketTask.close()
  305. that.globalData.socketTask = null
  306. clearTimeout(that.globalData.timeoutObj);
  307. clearTimeout(that.globalData.reconnectTimeOutObj);
  308. uni.hideLoading(); // 关闭通信异常弹框
  309. },
  310. //允许程序后台运行,以持续获取GPS位置
  311. wakeLock() {
  312. //Android
  313. const main = plus.android.runtimeMainActivity();
  314. console.warn('--------- walk lock------------ dsd', main)
  315. const Context = plus.android.importClass("android.content.Context");
  316. const PowerManager = plus.android.importClass("android.os.PowerManager");
  317. const pm = main.getSystemService(Context.POWER_SERVICE);
  318. this.g_wakelock = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "ANY_NAME");
  319. this.g_wakelock.acquire();
  320. },
  321. //结束程序后台运行
  322. releaseWakeLock() {
  323. if (this.g_wakelock != null && this.g_wakelock.isHeld()) {
  324. this.g_wakelock.release();
  325. this.g_wakelock = null;
  326. }
  327. },
  328. }
  329. }
  330. </script>
  331. <!-- // App.vue文件 中首行的位置引入,注意给style标签加入lang="scss"属性 -->
  332. <style lang="scss">
  333. @import './common/zego-nvue.css';
  334. /* 注意要写在第一行,同时给style标签加入lang="scss"属性 */
  335. @import "uview-ui/index.scss";
  336. </style>