App.vue 10 KB

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