Compare commits
	
		
			No commits in common. "3a561a504e2f1d2c1bdc069d55d9df96c6ba0559" and "fc639d546b92664e49084f14622c8aec74f29f7f" have entirely different histories.
		
	
	
		
			3a561a504e
			...
			fc639d546b
		
	
		
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 335 KiB | 
							
								
								
									
										2
									
								
								env.js
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								env.js
									
									
									
									
									
								
							| @ -9,7 +9,7 @@ module.exports = { | |||||||
|   dev: { |   dev: { | ||||||
|     MODE: 'dev', |     MODE: 'dev', | ||||||
|     // VUE_APP_API_URL: 'http://122.51.230.86:8099/',
 |     // VUE_APP_API_URL: 'http://122.51.230.86:8099/',
 | ||||||
|     VUE_APP_API_URL: 'http://192.168.1.4:8099/', |     VUE_APP_API_URL: 'http://192.168.1.17:8099/', | ||||||
|     VUE_APP_WEBSOCKET: 'ws://localhost:8099/ws/asset/' |     VUE_APP_WEBSOCKET: 'ws://localhost:8099/ws/asset/' | ||||||
|   }, |   }, | ||||||
|   // 生产环境 接口请求地址 (http)或(https)://www.a.com(换成你的域名)/api 非独立部署默认为空
 |   // 生产环境 接口请求地址 (http)或(https)://www.a.com(换成你的域名)/api 非独立部署默认为空
 | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ export default { | |||||||
|   plugins: [ |   plugins: [ | ||||||
|     '~plugins/main', |     '~plugins/main', | ||||||
|     '~plugins/axios', |     '~plugins/axios', | ||||||
|     // { src: "~plugins/websocket.js", ssr: true },
 |     { src: "~plugins/websocket.js", ssr: true }, | ||||||
|     { src: "~plugins/router.js", ssr: true }, |     { src: "~plugins/router.js", ssr: true }, | ||||||
|     { src: "~plugins/i18n.js", ssr: true }, |     { src: "~plugins/i18n.js", ssr: true }, | ||||||
|     { src: "~plugins/element-ui.js", ssr: true }, |     { src: "~plugins/element-ui.js", ssr: true }, | ||||||
|  | |||||||
							
								
								
									
										54
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										54
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @ -17,7 +17,6 @@ | |||||||
|         "core-js": "^3.43.0", |         "core-js": "^3.43.0", | ||||||
|         "dayjs": "^1.11.7", |         "dayjs": "^1.11.7", | ||||||
|         "element-ui": "^2.15.14", |         "element-ui": "^2.15.14", | ||||||
|         "fingerprintjs2": "^2.1.4", |  | ||||||
|         "jquery": "^3.4.1", |         "jquery": "^3.4.1", | ||||||
|         "lru-cache": "^7.18.3", |         "lru-cache": "^7.18.3", | ||||||
|         "nuxt": "2.15.0", |         "nuxt": "2.15.0", | ||||||
| @ -4179,15 +4178,6 @@ | |||||||
|         "url": "https://github.com/sponsors/sindresorhus" |         "url": "https://github.com/sponsors/sindresorhus" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/bindings": { |  | ||||||
|       "version": "1.5.0", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/bindings/-/bindings-1.5.0.tgz", |  | ||||||
|       "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", |  | ||||||
|       "optional": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "file-uri-to-path": "1.0.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/bluebird": { |     "node_modules/bluebird": { | ||||||
|       "version": "3.7.2", |       "version": "3.7.2", | ||||||
|       "resolved": "https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz", |       "resolved": "https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz", | ||||||
| @ -6932,12 +6922,6 @@ | |||||||
|         "url": "https://opencollective.com/webpack" |         "url": "https://opencollective.com/webpack" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/file-uri-to-path": { |  | ||||||
|       "version": "1.0.0", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", |  | ||||||
|       "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", |  | ||||||
|       "optional": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/fill-range": { |     "node_modules/fill-range": { | ||||||
|       "version": "7.1.1", |       "version": "7.1.1", | ||||||
|       "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.1.1.tgz", |       "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.1.1.tgz", | ||||||
| @ -7015,12 +6999,6 @@ | |||||||
|         "micromatch": "^4.0.2" |         "micromatch": "^4.0.2" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/fingerprintjs2": { |  | ||||||
|       "version": "2.1.4", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/fingerprintjs2/-/fingerprintjs2-2.1.4.tgz", |  | ||||||
|       "integrity": "sha512-veP2yVsnYvjDVkzZMyIEwpqCAQfsBLH+U4PK5MlFAnLjZrttbdRqEArE1fPcnJFz5oS5CrdONbsV7J6FGpIJEQ==", |  | ||||||
|       "deprecated": "Package has been renamed to @fingerprintjs/fingerprintjs. Install @fingerprintjs/fingerprintjs to get updates." |  | ||||||
|     }, |  | ||||||
|     "node_modules/flat": { |     "node_modules/flat": { | ||||||
|       "version": "5.0.2", |       "version": "5.0.2", | ||||||
|       "resolved": "https://registry.npmmirror.com/flat/-/flat-5.0.2.tgz", |       "resolved": "https://registry.npmmirror.com/flat/-/flat-5.0.2.tgz", | ||||||
| @ -9545,12 +9523,6 @@ | |||||||
|       "resolved": "https://registry.npmmirror.com/mute-stream/-/mute-stream-0.0.8.tgz", |       "resolved": "https://registry.npmmirror.com/mute-stream/-/mute-stream-0.0.8.tgz", | ||||||
|       "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" |       "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" | ||||||
|     }, |     }, | ||||||
|     "node_modules/nan": { |  | ||||||
|       "version": "2.23.0", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/nan/-/nan-2.23.0.tgz", |  | ||||||
|       "integrity": "sha512-1UxuyYGdoQHcGg87Lkqm3FzefucTa0NAiOcuRsDmysep3c1LVCRK2krrUDafMWtjSG04htvAmvg96+SDknOmgQ==", |  | ||||||
|       "optional": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/nanoid": { |     "node_modules/nanoid": { | ||||||
|       "version": "3.3.11", |       "version": "3.3.11", | ||||||
|       "resolved": "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.11.tgz", |       "resolved": "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.11.tgz", | ||||||
| @ -20409,15 +20381,6 @@ | |||||||
|       "resolved": "https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.3.0.tgz", |       "resolved": "https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.3.0.tgz", | ||||||
|       "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==" |       "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==" | ||||||
|     }, |     }, | ||||||
|     "bindings": { |  | ||||||
|       "version": "1.5.0", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/bindings/-/bindings-1.5.0.tgz", |  | ||||||
|       "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", |  | ||||||
|       "optional": true, |  | ||||||
|       "requires": { |  | ||||||
|         "file-uri-to-path": "1.0.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "bluebird": { |     "bluebird": { | ||||||
|       "version": "3.7.2", |       "version": "3.7.2", | ||||||
|       "resolved": "https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz", |       "resolved": "https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz", | ||||||
| @ -22534,12 +22497,6 @@ | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "file-uri-to-path": { |  | ||||||
|       "version": "1.0.0", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", |  | ||||||
|       "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", |  | ||||||
|       "optional": true |  | ||||||
|     }, |  | ||||||
|     "fill-range": { |     "fill-range": { | ||||||
|       "version": "7.1.1", |       "version": "7.1.1", | ||||||
|       "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.1.1.tgz", |       "resolved": "https://registry.npmmirror.com/fill-range/-/fill-range-7.1.1.tgz", | ||||||
| @ -22604,11 +22561,6 @@ | |||||||
|         "micromatch": "^4.0.2" |         "micromatch": "^4.0.2" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "fingerprintjs2": { |  | ||||||
|       "version": "2.1.4", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/fingerprintjs2/-/fingerprintjs2-2.1.4.tgz", |  | ||||||
|       "integrity": "sha512-veP2yVsnYvjDVkzZMyIEwpqCAQfsBLH+U4PK5MlFAnLjZrttbdRqEArE1fPcnJFz5oS5CrdONbsV7J6FGpIJEQ==" |  | ||||||
|     }, |  | ||||||
|     "flat": { |     "flat": { | ||||||
|       "version": "5.0.2", |       "version": "5.0.2", | ||||||
|       "resolved": "https://registry.npmmirror.com/flat/-/flat-5.0.2.tgz", |       "resolved": "https://registry.npmmirror.com/flat/-/flat-5.0.2.tgz", | ||||||
| @ -24445,12 +24397,6 @@ | |||||||
|       "resolved": "https://registry.npmmirror.com/mute-stream/-/mute-stream-0.0.8.tgz", |       "resolved": "https://registry.npmmirror.com/mute-stream/-/mute-stream-0.0.8.tgz", | ||||||
|       "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" |       "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" | ||||||
|     }, |     }, | ||||||
|     "nan": { |  | ||||||
|       "version": "2.23.0", |  | ||||||
|       "resolved": "https://registry.npmmirror.com/nan/-/nan-2.23.0.tgz", |  | ||||||
|       "integrity": "sha512-1UxuyYGdoQHcGg87Lkqm3FzefucTa0NAiOcuRsDmysep3c1LVCRK2krrUDafMWtjSG04htvAmvg96+SDknOmgQ==", |  | ||||||
|       "optional": true |  | ||||||
|     }, |  | ||||||
|     "nanoid": { |     "nanoid": { | ||||||
|       "version": "3.3.11", |       "version": "3.3.11", | ||||||
|       "resolved": "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.11.tgz", |       "resolved": "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.11.tgz", | ||||||
|  | |||||||
| @ -20,7 +20,6 @@ | |||||||
|     "core-js": "^3.43.0", |     "core-js": "^3.43.0", | ||||||
|     "dayjs": "^1.11.7", |     "dayjs": "^1.11.7", | ||||||
|     "element-ui": "^2.15.14", |     "element-ui": "^2.15.14", | ||||||
|     "fingerprintjs2": "^2.1.4", |  | ||||||
|     "jquery": "^3.4.1", |     "jquery": "^3.4.1", | ||||||
|     "lru-cache": "^7.18.3", |     "lru-cache": "^7.18.3", | ||||||
|     "nuxt": "2.15.0", |     "nuxt": "2.15.0", | ||||||
|  | |||||||
| @ -154,15 +154,12 @@ | |||||||
|         </b-form> |         </b-form> | ||||||
|       </div> |       </div> | ||||||
|     </div> |     </div> | ||||||
|     <!--    聊天记录弹出框--> |  | ||||||
|     <chat-form ref="chatFrom"></chat-form> |  | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import vuePhotoZoomPro from 'vue-photo-zoom-pro'; | import vuePhotoZoomPro from 'vue-photo-zoom-pro'; | ||||||
| import 'vue-photo-zoom-pro/dist/style/vue-photo-zoom-pro.css'; | import 'vue-photo-zoom-pro/dist/style/vue-photo-zoom-pro.css'; | ||||||
| import chatForm from "./chatForm"; |  | ||||||
| if (process.client) { | if (process.client) { | ||||||
|   var { swiper, swiperSlide } = require("vue-awesome-swiper"); |   var { swiper, swiperSlide } = require("vue-awesome-swiper"); | ||||||
| } | } | ||||||
| @ -174,7 +171,6 @@ export default { | |||||||
|     swiper, |     swiper, | ||||||
|     swiperSlide, |     swiperSlide, | ||||||
|     vuePhotoZoomPro, |     vuePhotoZoomPro, | ||||||
|     chatForm |  | ||||||
|   }, |   }, | ||||||
|   data() { |   data() { | ||||||
|     return { |     return { | ||||||
| @ -240,12 +236,9 @@ export default { | |||||||
|       e.preventDefault() |       e.preventDefault() | ||||||
|       console.log(this.dataForm); |       console.log(this.dataForm); | ||||||
|     }, |     }, | ||||||
|     /**打开聊天窗口,并建立连接*/ |  | ||||||
|     chat(){ |     chat(){ | ||||||
|       this.$refs.chatFrom.show() |       this.$store.dispatch('modules/websocket/websocket_send', 'kehuduan,userface,hello'); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  | |||||||
| @ -1,220 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <!-- 选择产品对话框 --> |  | ||||||
|   <el-dialog :title="title" :visible.sync="open" @close="close" width="800px" append-to-body> |  | ||||||
|     <el-card style="height: 600px"> |  | ||||||
|       <el-container class="AddressBook-container"> |  | ||||||
|         <el-header class="AddressBook-header" style="height: 30px"> |  | ||||||
|           <span></span> |  | ||||||
|           <!--          <span style="margin-left: 500px">当前在线人数:{{count.split(',')[1]}}</span>--> |  | ||||||
|         </el-header> |  | ||||||
|         <el-container> |  | ||||||
|           <el-container> |  | ||||||
|             <el-main class="AddressBook-main"> |  | ||||||
|               <el-row style="margin-top: 20px" v-for="item in message" :key="item.createTime"> |  | ||||||
|                 <el-row v-if="item.dataFrom==='customer'" type="flex" justify="end"> |  | ||||||
|                   <el-col :span="8"> |  | ||||||
|                     <el-card shadow="always" :style="'item.dataFrom===customer'?'':'background-color: greenyellow;'"> |  | ||||||
|                       {{ item.content }} |  | ||||||
|                     </el-card> |  | ||||||
|                   </el-col> |  | ||||||
|                   <el-col :span="2"> |  | ||||||
|                     <el-avatar shape="square" size="medium" icon="el-icon-user-solid" |  | ||||||
|                                style="margin-left: 5px"></el-avatar> |  | ||||||
|                   </el-col> |  | ||||||
|                 </el-row> |  | ||||||
|                 <el-row v-else type="flex" justify="start"> |  | ||||||
|                   <el-col :span="2"> |  | ||||||
|                     <el-avatar shape="square" size="medium" icon="el-icon-user-solid" |  | ||||||
|                                style="margin-left: 5px"></el-avatar> |  | ||||||
|                   </el-col> |  | ||||||
|                   <el-col :span="8"> |  | ||||||
|                     <el-card shadow="always" style="background-color: greenyellow"> |  | ||||||
|                       {{ item.content }} |  | ||||||
|                     </el-card> |  | ||||||
|                   </el-col> |  | ||||||
| 
 |  | ||||||
|                 </el-row> |  | ||||||
|               </el-row> |  | ||||||
|             </el-main> |  | ||||||
|             <el-footer class="uesrtext" style="height:150px"> |  | ||||||
| 
 |  | ||||||
|               <el-input type="textarea" |  | ||||||
|                         class="inputT" |  | ||||||
|                         placeholder="按 Enter 发送" v-model="text" |  | ||||||
|                         @keyup.enter.native="sendToServer" |  | ||||||
|               ></el-input> |  | ||||||
|               <el-button type="primary" icon="el-icon-s-promotion" @click="sendToServer"></el-button> |  | ||||||
|             </el-footer> |  | ||||||
|           </el-container> |  | ||||||
|         </el-container> |  | ||||||
|       </el-container> |  | ||||||
|     </el-card> |  | ||||||
|   </el-dialog> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import Fingerprint2 from "fingerprintjs2"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: 'chatForm', |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // |  | ||||||
|       open: false, |  | ||||||
|       title: null, |  | ||||||
|       //消息 |  | ||||||
|       message: [], |  | ||||||
|       //发送消息内容 |  | ||||||
|       text: null, |  | ||||||
|       //聊天信息 |  | ||||||
|       chatMain: {}, |  | ||||||
| 
 |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   destroyed: function () { |  | ||||||
|     // 离开页面生命周期函数 |  | ||||||
|     this.$store.dispatch('modules/websocket/websocket_close') |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   mounted() { |  | ||||||
| 
 |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   methods: { |  | ||||||
|     /**用户列表*/ |  | ||||||
|     getUserList() { |  | ||||||
| 
 |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     /** |  | ||||||
|      * 组件显示 |  | ||||||
|      */ |  | ||||||
|     show() { |  | ||||||
|       this.open = true |  | ||||||
|       this.getChatMain() |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     /**获取原有聊天记录*/ |  | ||||||
|     getChatMain() { |  | ||||||
|       //获取当前浏览器唯一id |  | ||||||
|       // this.$store.dispatch('modules/websocket/websocket_send', murmur + ',userface,hello'); |  | ||||||
|       //获取当前浏览器唯一id |  | ||||||
|       Fingerprint2.get((components) => { |  | ||||||
|         const values = components.map((component) => component.value); |  | ||||||
|         const fingerprintHash = Fingerprint2.x64hash128(values.join(''), 31); |  | ||||||
|         const data = { |  | ||||||
|           cusCode: fingerprintHash, |  | ||||||
|           tenantId: 'main', |  | ||||||
|         }; |  | ||||||
|         // 这里使用箭头函数,确保 `this` 指向当前 Vue 实例 |  | ||||||
|         this.$axios.$post('/web/chatMain', data).then((res) => { |  | ||||||
|           if (res.id != null) { |  | ||||||
|             this.chatMain = res; |  | ||||||
|             const websocketUrl = `ws://localhost:8099/ws/asset/${fingerprintHash}`; |  | ||||||
|             // 调用Vuex dispatch,初始化WebSocket |  | ||||||
|             this.$store.dispatch('modules/websocket/websocket_init', websocketUrl) |  | ||||||
|                 .then(() => { |  | ||||||
|                   console.log('WebSocket 初始化成功'); |  | ||||||
|                 }) |  | ||||||
|                 .catch((err) => { |  | ||||||
|                   console.error('WebSocket 初始化失败:', err); |  | ||||||
|                 }); |  | ||||||
|           } else { |  | ||||||
|             console.error('请求返回错误:', res); |  | ||||||
|           } |  | ||||||
|         }).catch(error => { |  | ||||||
|           console.error('请求错误:', error); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     /**弹窗关闭方法*/ |  | ||||||
|     close() { |  | ||||||
|       this.$store.dispatch('modules/websocket/websocket_close') |  | ||||||
|     }, |  | ||||||
| 
 |  | ||||||
|     /**发送消息*/ |  | ||||||
|     sendToServer() { |  | ||||||
|       this.$store.dispatch('modules/websocket/websocket_send',"customer," + this.text); |  | ||||||
|       this.message=this.$store.state.modules.websocket.messages; |  | ||||||
|       this.text='' |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style lang="scss" scoped> |  | ||||||
| 
 |  | ||||||
| .el-card { |  | ||||||
|   background-color: transparent; |  | ||||||
|   border: none; |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .AddressBook-container { |  | ||||||
|   height: 100%; |  | ||||||
|   width: 100%; |  | ||||||
|   border: 1px solid #909399; |  | ||||||
|   border-radius: 3px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .AddressBook-header { |  | ||||||
|   background-color: #0b60b5; |  | ||||||
|   color: #d3dce6; |  | ||||||
|   display: flex; |  | ||||||
|   align-items: center; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .AddressBook-main { |  | ||||||
|   height: 380px; |  | ||||||
|   background-color: #DCDFE6; |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .AddressBook-aside { |  | ||||||
|   background-color: #909399; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .userList { |  | ||||||
|   padding-top: 3px; |  | ||||||
|   box-shadow: 0px 3px 3px #888888; |  | ||||||
| 
 |  | ||||||
|   .name { |  | ||||||
|     vertical-align: top; |  | ||||||
|     /*margin-top: 2px;*/ |  | ||||||
|     margin-left: 15px; |  | ||||||
|     font-size: 15px; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .uesrtext { |  | ||||||
|   position: relative; |  | ||||||
|   bottom: 0; |  | ||||||
|   right: 0; |  | ||||||
|   width: 100%; |  | ||||||
|   height: 100%; |  | ||||||
|   border-top: solid 1px #DDD; |  | ||||||
|   background-color: white; |  | ||||||
| 
 |  | ||||||
|   .inputT { |  | ||||||
|     padding-top: 10px; |  | ||||||
|     width: 100%; |  | ||||||
|     height: 200%; |  | ||||||
|     border: none; |  | ||||||
|     outline: none; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   .el-button { |  | ||||||
|     position: absolute; |  | ||||||
|     bottom: 10px; |  | ||||||
|     right: 10px; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .message-avatar { |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -2,32 +2,8 @@ import Vue from 'vue' | |||||||
| import {  | import {  | ||||||
|   // 添加你需要的其他组件
 |   // 添加你需要的其他组件
 | ||||||
|   Tree, |   Tree, | ||||||
|   Drawer, |   Drawer | ||||||
|   Dialog, |  | ||||||
|   Button, |  | ||||||
|   Card, |  | ||||||
|   Container, |  | ||||||
|   Header, |  | ||||||
|   Aside, |  | ||||||
|   Input, |  | ||||||
|   Main, |  | ||||||
|   Footer, |  | ||||||
|   Row, |  | ||||||
|   Col, |  | ||||||
|   Avatar |  | ||||||
| } from 'element-ui' | } from 'element-ui' | ||||||
| 
 | 
 | ||||||
| Vue.use(Tree) | Vue.use(Tree) | ||||||
| Vue.use(Drawer) | Vue.use(Drawer) | ||||||
| Vue.use(Dialog) |  | ||||||
| Vue.use(Button) |  | ||||||
| Vue.use(Card) |  | ||||||
| Vue.use(Container) |  | ||||||
| Vue.use(Header) |  | ||||||
| Vue.use(Aside) |  | ||||||
| Vue.use(Input) |  | ||||||
| Vue.use(Main) |  | ||||||
| Vue.use(Footer) |  | ||||||
| Vue.use(Row) |  | ||||||
| Vue.use(Col) |  | ||||||
| Vue.use(Avatar) |  | ||||||
| @ -1,13 +1,6 @@ | |||||||
| 
 | export default ({ store }) => { | ||||||
| // import Fingerprint2 from 'fingerprintjs2';
 |     if (process.client){ | ||||||
| //
 |         const websocketUrl = 'ws://localhost:8099/ws/asset/kehuduan' | ||||||
| // export default ({ store }) => {
 |         store.dispatch('modules/websocket/websocket_init', websocketUrl) | ||||||
| //     if (process.client){
 |     } | ||||||
| //         const fingerprint = Fingerprint2.get((components) => {
 | } | ||||||
| //             const values = components.map((component)=>component.value)
 |  | ||||||
| //             const murmur = Fingerprint2.x64hash128(values.join(''),31)
 |  | ||||||
| //             const websocketUrl = 'ws://localhost:8099/ws/asset/'+murmur
 |  | ||||||
| //             store.dispatch('modules/websocket/websocket_init', websocketUrl)
 |  | ||||||
| //         })
 |  | ||||||
| //     }
 |  | ||||||
| // }
 |  | ||||||
| @ -15,16 +15,16 @@ export const mutations = { | |||||||
|       console.log("WebSocket连接成功"); |       console.log("WebSocket连接成功"); | ||||||
|     }; |     }; | ||||||
|     state.socket.onmessage = function (e) { |     state.socket.onmessage = function (e) { | ||||||
|       console.log(e,'接收到的消息') |  | ||||||
|       if (e.data.startsWith("C")) { |       if (e.data.startsWith("C")) { | ||||||
|         state.count = e.data; |         state.count = e.data; | ||||||
|       } |       } | ||||||
|       else if (e.data.startsWith("系统通知")){ |       else if (e.data.startsWith("系统通知")){ | ||||||
|         state.notices.push(e.data); |         state.notices.push(e.data); | ||||||
|  |         console.log(state.notices); | ||||||
|       } |       } | ||||||
|       else { |       else { | ||||||
|         state.messages.push(JSON.parse(e.data)); |         state.message.push(JSON.parse(e.data)); | ||||||
|         console.log(state.messages); |         console.log(state.message); | ||||||
|       } |       } | ||||||
|     }; |     }; | ||||||
|     state.socket.onerror= function () { |     state.socket.onerror= function () { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user