项目实训—图片存储

图片存储

指定外部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<String, Object> paramMap = new HashMap<String, Object>();
    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 = "<div class=\"el-row\" style=\"padding: 5px 0\">\n" +
            "  <div class=\"el-col el-col-22\" style=\"text-align: right; padding-right: 10px\">\n" +
            "    <div class=\"tip left\">" + text + "</div>\n" +
            "  </div>\n" +
            "  <div class=\"el-col el-col-2\">\n" +
            "  <span class=\"el-avatar el-avatar--circle\" style=\"height: 40px; width: 40px; line-height: 40px;\">\n" +
            "    <img src=\"https://cube.elemecdn.com/3/7c/3ea6beec64369c2642b92c6726f1epng.png\" style=\"object-fit: cover;\">\n" +
            "  </span>\n" +
            "  </div>\n" +
            "</div>";
      } else if (remoteUser) {   // remoteUser表示远程用户聊天消息,蓝色的气泡
        html = "<div class=\"el-row\" style=\"padding: 5px 0\">\n" +
            "  <div class=\"el-col el-col-2\" style=\"text-align: right\">\n" +
            "  <span class=\"el-avatar el-avatar--circle\" style=\"height: 40px; width: 40px; line-height: 40px;\">\n" +
            "    <img src=\"https://cube.elemecdn.com/3/7c/3ea6beec64369c2642b92c6726f1epng.png\" style=\"object-fit: cover;\">\n" +
            "  </span>\n" +
            "  </div>\n" +
            "  <div class=\"el-col el-col-22\" style=\"text-align: left; padding-left: 10px\">\n" +
            "    <div class=\"tip right\">" + text + "</div>\n" +
            "  </div>\n" +
            "</div>";
      }
      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发生了错误");
        }
      }

### 回答1: Android Studio实训项目是一种针对Android应用开发的实践性项目,旨在帮助学生通过实践掌握Android应用开发的基本技能和知识。该项目通常由学校或培训机构提供,包括一系列的实践任务和指导,学生需要在规定的时间内完成这些任务,并提交相应的作品。通过这样的实践项目,学生可以更好地理解Android应用开发的流程和技术,提高自己的实践能力和综合素质。 ### 回答2: Android Studio实训项目是一种基于Android开发的应用程序开发训练项目。在这个项目中,学生们将学习使用Android Studio开发环境,并通过完成一系列编程任务来提升他们的Android开发技能。 这个实训项目的目标是帮助学生熟悉Android应用程序的开发过程,包括UI设计、数据存储、网络通信等方面。学生们将学习如何创建一个基本的Android应用程序,掌握布局设计和界面元素的使用方法。 在实训项目的过程中,学生们将学习如何编写代码以实现应用程序的功能。他们将学习如何处理用户输入、执行计算、处理图像等等。通过完成这些任务,学生们将提高他们的编程技巧和解决问题的能力。 本实训项目也将涉及到团队合作。学生们将分为小组,每个小组负责一个具体的任务。他们将学习如何与团队成员合作,如何分工合作,如何协调工作进度等等。通过团队合作,学生们将更好地理解软件开发的实践,提高他们的团队协作能力。 最后,学生们将完成一个完整的Android应用程序。这个应用程序将集成他们在实训项目中学到的知识和技能。他们将展示他们设计和开发Android应用程序的能力。 总之,Android Studio实训项目是一种锻炼学生们Android开发技能的训练项目。通过这个项目,学生们将学习如何使用Android Studio开发环境,如何设计和开发Android应用程序,并提高他们的团队合作能力。这将为他们未来在软件开发领域的职业生涯奠定良好的基础。 ### 回答3: Android Studio实训项目是一种通过实践的方式来学习和掌握Android应用开发的项目。该项目通常由一系列的任务和目标组成,旨在让学生熟悉应用开发的基本概念、工具和技术。 在Android Studio实训项目中,学生将会学习如何使用Android Studio这个强大的开发工具,掌握基本的代码编写和调试技巧,理解应用程序的生命周期和UI设计原则。 在实训项目中,学生需要完成一系列的编码任务,例如创建一个简单的计算器应用程序、设计一个界面友好的记事本应用、实现一个有各种特效和过渡动画的图片浏览器等等。通过这些任务,学生可以逐步熟悉并掌握Android应用开发的各个方面,如布局设计、数据存储、用户输入处理、网络连接等。 实训项目通常会设立一定的时间限制,学生需要在规定的时间内完成各项任务。在整个项目过程中,学生可以借助老师或助教的指导和帮助,解决遇到的问题和困难。 完成Android Studio实训项目后,学生将会有一个完整的、可演示的Android应用程序作品,并且在完成过程中积累了宝贵的开发经验。这将为他们之后的Android开发工作或进一步学习打下坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值