项目实训(简)

项目实训(简),第1张

图片存储

指定外部oss存储,比如阿里云、七牛云、git仓库,项目选择gitee仓库,首先建一个新仓库 -- 配置密钥 -- java模拟http请求发送上传请求 -- 返回访问链接存数据库

@Override
public String upLoad(InputStream inputStream, String path) {
    //根据存储地区创建上传对象
    System.out.println(inputStream + "  " + path);
    //设置转存到Gitee仓库参数
    String paramImgFile = Base64.encode(inputStream);
    Map paramMap = new HashMap();
    paramMap.put("access_token", GiteeImgBed.ACCESS_TOKEN);
    paramMap.put("message", GiteeImgBed.ADD_MESSAGE);
    paramMap.put("content", paramImgFile);
    //转存文件路径
    String targetDir =GiteeImgBed.PATH +  path;
    String requestUrl = String.format(GiteeImgBed.CREATE_REPOS_URL, GiteeImgBed.OWNER,
            GiteeImgBed.REPO_NAME, targetDir);
    System.out.println("Url" + requestUrl);
    //工具类模拟post请求
    String resultJson = HttpUtil.post(requestUrl, paramMap);
    return getUrlFromJson(resultJson);//自己实现从json中提取指定的字符串
}
聊天
 send() {
      if (!this.chatUser) {
        this.$message({type: 'warning', message: "请选择聊天对象"})
        return;
      }
      if (!this.text) {
        this.$message({type: 'warning', message: "请输入内容"})
      } else {
        if (typeof (WebSocket) == "undefined") {
          console.log("您的浏览器不支持WebSocket");
        } else {
          console.log("您的浏览器支持WebSocket");
          // 组装待发送的消息 json
          // {"from": "zhang", "to": "admin", "text": "聊天文本"}
          let message = {from: this.user.username, to: this.chatUser, text: this.text}
          socket.send(JSON.stringify(message));  // 将组装好的json发送给服务端,由服务端进行转发
          this.messages.push({user: this.user.username, text: this.text})
          // 构建消息内容,本人消息
          this.createContent(null, this.user.username, this.text)
          this.text = '';
        }
      }
    },
 createContent(remoteUser, nowUser, text) {  // 这个方法是用来将 json的聊天消息数据转换成 html的。
      let html
      // 当前用户消息
      if (nowUser) { // nowUser 表示是否显示当前用户发送的聊天消息,绿色气泡
        html = "\n" +
            "  \n" +
            "    " + text + "\n" +
            "  \n" +
            "  \n" +
            "  \n" +
            "    \n" +
            "  \n" +
            "  \n" +
            "";
      } else if (remoteUser) {   // remoteUser表示远程用户聊天消息,蓝色的气泡
        html = "\n" +
            "  \n" +
            "  \n" +
            "    \n" +
            "  \n" +
            "  \n" +
            "  \n" +
            "    " + text + "\n" +
            "  \n" +
            "";
      }
      console.log(html)
      this.content += html;
    },
 init() {
      this.user = sessionStorage.getItem("user") ? JSON.parse(sessionStorage.getItem("user")) : {}
      let username = this.user.username;
      let _this = this;
      if (typeof (WebSocket) == "undefined") {
        console.log("您的浏览器不支持WebSocket");
      } else {
        console.log("您的浏览器支持WebSocket");
        let socketUrl = "ws://localhost:9090/imserver/" + username;
        if (socket != null) {
          socket.close();
          socket = null;
        }
        // 开启一个websocket服务
        socket = new WebSocket(socketUrl);
        //打开事件
        socket.onopen = function () {
          console.log("websocket已打开");
        };
        //  浏览器端收消息,获得从服务端发送过来的文本消息
        socket.onmessage = function (msg) {
          console.log("收到数据====" + msg.data)
          let data = JSON.parse(msg.data)  // 对收到的json数据进行解析, 类似这样的: {"users": [{"username": "zhang"},{ "username": "admin"}]}
          if (data.users) {  // 获取在线人员信息
            _this.users = data.users.filter(user => user.username !== username)  // 获取当前连接的所有用户信息,并且排除自身,自己不会出现在自己的聊天列表里
          } else {
            // 如果服务器端发送过来的json数据 不包含 users 这个key,那么发送过来的就是聊天文本json数据
            //  // {"from": "zhang", "text": "hello"}
            if (data.from === _this.chatUser) {
              _this.messages.push(data)
              // 构建消息内容
              _this.createContent(data.from, null, data.text)
            }
          }
        };
        //关闭事件
        socket.onclose = function () {
          console.log("websocket已关闭");
        };
        //发生了错误事件
        socket.onerror = function () {
          console.log("websocket发生了错误");
        }
      }

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/729410.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-27
下一篇 2022-04-27

发表评论

登录后才能评论

评论列表(0条)

保存