文件存储解决方案-阿里云OSS

文章目录

    • 1.菜单分级显示问题
        • 1.问题引出
          • 1.苹果灯,放到节能灯下面也就是id大于127
          • 2.查看菜单,并没有出现苹果灯
          • 3.放到灯具下面id=42,就可以显示
        • 2.问题分析和解决
          • 1.判断可能出现问题的位置
          • 2.找到递归返回树形菜单数据的位置
          • 3.这里出现问题的原因是,使用等号来比较了包装类的数值,修改为equals即可
          • 4.关于Long类型的机制
            • 1.编写测试用例
            • 2.结果
            • 3.debug 分析
          • 5.测试
            • 1.此时将苹果灯的id设置成652
            • 2.成功显示
    • 2.文件存储解决方案
        • 1.文件存储方案分析
        • 2.OSS在微服务架构位置
        • 3.上传方式
          • 1.普通上传方式
          • 2.服务端签名后直传
        • 4.创建Bucket
          • 1.进入对象存储控制台
          • 2.创建Bucket
          • 3.填写配置信息
          • 4.查看Bucket
            • 1.文件列表查看文件
            • 2.如果想要访问文件就使用url
        • 5.使用原生SDK上传文件到Bucket
          • 1.找到OSS的SDK参考文档
          • 2.sunliving-commodity 导入依赖这里选择3.5.0版本
          • 3.编写一个TestConroller
          • 4.找到上传文件代码并粘贴到TestConroller,然后引包,抛出异常
          • 5.回到控制台找到指定信息
            • 1.Endpoint
            • 2.找到AccessKey管理
            • 3.选择开始使用子用户的AccessKey
            • 4.创建用户
            • 5.填写信息
            • 6.验证一下
            • 7.复制一份并保留,AccessKey Secret 以后不会再出现
            • 8.选择授权 -> 新增授权
            • 9.为刚才的子用户授予权限
            • 10.查看子用户信息
          • 6.将上一步找到的三个信息填到代码中并指定其余信息
            • 1.Endpoint(前面需要加https://)
            • 2.设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET
            • 3.bucketName
            • 4.填写两个文件路径
          • 7.测试
            • 1.启动 sunliving-commodity 模块
            • 2.浏览器访问 http://localhost:9091/test 发现500了,是环境变量未读取成功
            • 3.第一次配置需要重启电脑后再次访问
            • 4.查看阿里云,上传成功了!
          • 8.注意事项
        • 6.使用SpringCloudAlibabaOSS上传文件到Bucket
          • 1.进入官网
          • 2.选择OSS的demo
          • 3.引入依赖(跟官网不一样)
          • 4.application.yml 配置信息
          • 5.编写代码
          • 6.测试
            • 1.浏览器访问 http://localhost:9091/test2
            • 2.上传成功
        • 7.服务端签名后直传(正片开始)
          • 1.官方文档
          • 2.创建sunliving-service模块
            • 1.创建maven模块
            • 2.查看父子pom.xml
          • 3.参考sunliving-commodity来配置pom.xml
          • 4.配置application.yml 填写对象存储所需信息
          • 5.编写启动类com/sun/sunliving/service/OssServiceApplication.java 启动测试
          • 6.目前文件目录
          • 7.参考官方文档编写 com/sun/sunliving/service/controller/OssServiceController.java
            • 1.官方文档
            • 2.OssServiceController 签名直传服务,返回一个签名
            • 3.测试
        • 8.通过前端上传图片到OSS
          • 1.将上传文件工具类放到 src/components下
          • 2.policy.js 向签名直传服务发送请求,获取签名(部署的时候注意修改)
          • 3.singleUpload.vue 就是一个上传文件的组件,修改action
          • 4.启动前后端项目测试
          • 5.src/views/modules/commodity/brand-add-or-update.vue 整合上传文件的控件
            • 1.引入导出上传文件的控件
            • 2.使用控件
            • 3.查看效果
            • 4.上传出现跨域问题
          • 6.上传文件跨域解决
            • 1.上传文件之前**通过浏览器**向后端发送请求,获取签名
            • 2.从renren-fast模块找到io/renren/config/CorsConfig.java的配置文件,放到后端项目即可解决第一个跨域
            • 3.重启后端,再次测试,还是有跨域问题
            • 4.第二个跨域问题分析
            • 5.在阿里云OSS解决跨域
            • 6.再次测试,成功!
          • 7.使用前端工具类进行文件上传步骤梳理
            • 1.保证后端传递的签名json对象使用data命名
            • 2.修改 policy.js 的url为后端返回签名的接口
            • 3.修改 el-upload 标签的action为 http:// + bucket + endpoint
            • 4.两个跨域问题
        • 9.品牌管理列表显示logo图片
          • 1.目前插入数据,显示的是url
            • 1.示意图
            • 2.通过访问这个url可以下载图片
          • 2.使用插槽机制显示图片
          • 3.结果展示

1.菜单分级显示问题

1.问题引出
1.苹果灯,放到节能灯下面也就是id大于127

image-20240413125405130

2.查看菜单,并没有出现苹果灯

image-20240413125613174

3.放到灯具下面id=42,就可以显示

image-20240413125847868

2.问题分析和解决
1.判断可能出现问题的位置

由于前端是直接调用了树形控件,展示了一下数据,所以应该是后端返回的数据的问题,则出现问题的位置应该是递归返回树形菜单数据的时候

2.找到递归返回树形菜单数据的位置

image-20240413131218590

3.这里出现问题的原因是,使用等号来比较了包装类的数值,修改为equals即可

image-20240413131434396

4.关于Long类型的机制
1.编写测试用例
package io.renren;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/4/13 13:16
 * @Version 1.0
 */
public class T1 {
    public static void main(String[] args) {
        Long num1 = 128l;
        Long num2 = 128l;
        System.out.println(num2 == num1);
    }
}

2.结果

image-20240413131802993

3.debug 分析
  • 如果包装类的值在-128 到 127之间,直接返回int类型,但是如果不在这个范围内就会返回一个Long类型
  • 此时使用等号比较的就是两个引用的地址了,由于都是new的,所以肯定不同

image-20240413131853332

5.测试
1.此时将苹果灯的id设置成652

image-20240413132446091

2.成功显示

image-20240413132513908

2.文件存储解决方案

1.文件存储方案分析

image-20240413134000624

2.OSS在微服务架构位置

image-20240413134458528

3.上传方式
1.普通上传方式

image-20240413135958474

2.服务端签名后直传

image-20240413140253228

4.创建Bucket
1.进入对象存储控制台

https://oss.console.aliyun.com/overview

image-20240413141743449

2.创建Bucket

image-20240413142031291

3.填写配置信息

image-20240413142619872

4.查看Bucket
1.文件列表查看文件

image-20240413142836396

2.如果想要访问文件就使用url

image-20240413142929341

5.使用原生SDK上传文件到Bucket
1.找到OSS的SDK参考文档

https://help.aliyun.com/zh/oss/developer-reference/java/?spm=a2c4g.11186623.0.0.35d25b0fLIE7J7

image-20240413143638506

2.sunliving-commodity 导入依赖这里选择3.5.0版本
        <dependency>
            <groupId>com.aliyun.oss</groupId>
            <artifactId>aliyun-sdk-oss</artifactId>
            <version>3.5.0</version>
        </dependency>

image-20240413143926785

3.编写一个TestConroller
package com.sun.sunliving.commodity.controller;

import com.sun.common.utils.R;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/4/13 14:40
 * @Version 1.0
 */
@RestController
@Slf4j
public class TestConroller {
    // 测试 aliyun-sdk-oss的使用
    // 编写方法上传文件到bucket

    @RequestMapping("/test")
    public R test() {

        return null;
    }
}

4.找到上传文件代码并粘贴到TestConroller,然后引包,抛出异常

image-20240413151722312

image-20240413144750030

5.回到控制台找到指定信息
1.Endpoint

image-20240413145600239

2.找到AccessKey管理

image-20240413145733962

3.选择开始使用子用户的AccessKey

image-20240413145857890

4.创建用户

image-20240413150031036

5.填写信息

image-20240413150134355

6.验证一下

image-20240413150154620

7.复制一份并保留,AccessKey Secret 以后不会再出现

image-20240413150408127

8.选择授权 -> 新增授权

image-20240413150757775

9.为刚才的子用户授予权限

image-20240413151022624

10.查看子用户信息

https://ram.console.aliyun.com/permissions

image-20240413151135565

6.将上一步找到的三个信息填到代码中并指定其余信息
1.Endpoint(前面需要加https://)
https://oss-cn-beijing.aliyuncs.com

image-20240413152448342

2.设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET

image-20240413152118752

echo %OSS_ACCESS_KEY_ID%
echo %OSS_ACCESS_KEY_SECRET%
可以查看win环境变量是否生效
3.bucketName

image-20240413152342933

image-20240413152507887

4.填写两个文件路径

image-20240413153002835

7.测试
1.启动 sunliving-commodity 模块

image-20240413153149593

2.浏览器访问 http://localhost:9091/test 发现500了,是环境变量未读取成功

image-20240413153628294

image-20240413153647357

3.第一次配置需要重启电脑后再次访问

image-20240413155656859

4.查看阿里云,上传成功了!

image-20240413155800339

8.注意事项

文件名可能会重复,可以根据时间来生成目录和文件名,之前写过

6.使用SpringCloudAlibabaOSS上传文件到Bucket
1.进入官网

https://github.com/alibaba/spring-cloud-alibaba/blob/2022.x/README-zh.md

2.选择OSS的demo

image-20240413160504696

image-20240413160604366

3.引入依赖(跟官网不一样)
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alicloud-oss</artifactId>
            <version>2.1.0.RELEASE</version>
        </dependency>
4.application.yml 配置信息

image-20240413161438839

5.编写代码
@RestController
@Slf4j
public class TestConroller {


    // 第二个测试
    @Resource
    private OSS ossClient;

    @RequestMapping("/test2")
    public R test2() {
        // 上传文件
        // 填写Bucket名称,例如examplebucket。
        String bucketName = "sunliving";
        // 填写Object完整路径,完整路径中不能包含Bucket名称,例如exampledir/exampleobject.txt。
        String objectName = "testdir/test2.jpg";
        // 填写本地文件的完整路径,例如D:\\localpath\\examplefile.txt。
        String filePath= "C:\\Users\\86156\\Desktop\\images\\3.25.png";

        PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, objectName, new File(filePath));
        ossClient.putObject(putObjectRequest);
        ossClient.shutdown();

        return R.ok();
    }
}
6.测试
1.浏览器访问 http://localhost:9091/test2

image-20240413162251054

2.上传成功

image-20240413162306041

7.服务端签名后直传(正片开始)
1.官方文档

https://help.aliyun.com/zh/oss/use-cases/obtain-signature-information-from-the-server-and-upload-data-to-oss?spm=a2c4g.11186623.0.0.518d5d03pHGK3i

https://help.aliyun.com/zh/oss/use-cases/java-1?spm=a2c4g.11186623.0.0.c14f5d03xW8RIq

image-20240413162845855

image-20240414102059697

2.创建sunliving-service模块
1.创建maven模块

image-20240413163820934

2.查看父子pom.xml

image-20240413163900598

image-20240413163925710

3.参考sunliving-commodity来配置pom.xml
    <!-- 添加描述信息 -->
    <description>sun(家居生活)-OSS服务</description>

    <!-- 导入SpringBoot父工程 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.8.RELEASE</version>
        <relativePath/> <!-- 当parent的groupId没有指向父工程时就需要加 -->
    </parent>

    <properties>
        <java.version>1.8</java.version>
        <!-- SpringCloud版本 2020.0.5-->
        <spring-cloud.version>2020.0.5</spring-cloud.version>
        <!-- 解决java: -source 1.5 中不支持 diamond 运算符 问题 -->
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>
        <!-- 阿里云对象存储依赖 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alicloud-oss</artifactId>
            <version>2.1.0.RELEASE</version>
        </dependency>
        <!-- SpringBoot web模块 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- SpringBoot test模块 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!-- 公共模块 -->
        <dependency>
            <groupId>com.sun.sunliving</groupId>
            <artifactId>sunliving-common</artifactId>
            <version>1.0-SNAPSHOT</version>
            <!-- 排除mybatis-plus-boot-starter, 因为不使用,就不会配置application.yml的mybatis-plus的部分,不排除会报错 -->
            <exclusions>
                <exclusion>
                    <groupId>com.baomidou</groupId>
                    <artifactId>mybatis-plus-boot-starter</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <!-- maven打包常规配置 -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
4.配置application.yml 填写对象存储所需信息
server:
  port: 7070
spring:
  cloud:
    alicloud:
      oss:
        endpoint: oss-cn-beijing.aliyuncs.com
        bucket: sunliving
      access-key: *******
      secret-key: *******

5.编写启动类com/sun/sunliving/service/OssServiceApplication.java 启动测试
package com.sun.sunliving.service;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/4/14 10:40
 * @Version 1.0
 */
@SpringBootApplication
public class OssServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(OssServiceApplication.class, args);
    }
}

image-20240414104340796

6.目前文件目录

image-20240414104456226

7.参考官方文档编写 com/sun/sunliving/service/controller/OssServiceController.java
1.官方文档

image-20240414104754482

2.OssServiceController 签名直传服务,返回一个签名
package com.sun.sunliving.service.controller;

import com.aliyun.oss.OSS;
import com.aliyun.oss.common.utils.BinaryUtil;
import com.aliyun.oss.model.MatchMode;
import com.aliyun.oss.model.PolicyConditions;
import com.sun.common.utils.R;
import org.codehaus.jettison.json.JSONObject;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.LinkedHashMap;
import java.util.Map;

/**
 * Description: 签名直传服务
 *
 * @Author sun
 * @Create 2024/4/14 10:45
 * @Version 1.0
 */
@RestController
public class OssServiceController {
    // 注入OSS对象
    @Resource
    private OSS ossClient;

    // 从配置文件中获取accessId
    @Value("${spring.cloud.alicloud.access-key}")
    private String accessId;

    // 从配置文件中获取endpoint
    @Value("${spring.cloud.alicloud.oss.endpoint}")
    private String endpoint;

    // 从配置文件中获取bucket
    @Value("${spring.cloud.alicloud.oss.bucket}")
    private String bucket;


    @RequestMapping("/oss/policy")
    public R policy() {
        try {
            // host的格式为 http:// + bucket + . + endpoint
            String host = "https://" + bucket + "." + endpoint;
            // 根据当前日期来存放文件
            String dir = new SimpleDateFormat("yyyy-MM-dd").format(new Date()) + "/";

            long expireTime = 30; // 默认30秒过期
            long expireEndTime = System.currentTimeMillis() + expireTime * 1000;
            Date expiration = new Date(expireEndTime);
            // PostObject请求最大可支持的文件大小为5 GB,即CONTENT_LENGTH_RANGE为5*1024*1024*1024。
            PolicyConditions policyConds = new PolicyConditions();
            policyConds.addConditionItem(PolicyConditions.COND_CONTENT_LENGTH_RANGE, 0, 1048576000);
            policyConds.addConditionItem(MatchMode.StartWith, PolicyConditions.COND_KEY, dir);

            String postPolicy = ossClient.generatePostPolicy(expiration, policyConds);
            byte[] binaryData = postPolicy.getBytes("utf-8");
            String encodedPolicy = BinaryUtil.toBase64String(binaryData);
            String postSignature = ossClient.calculatePostSignature(postPolicy);

            // 返回的信息
            Map<String, String> respMap = new LinkedHashMap<String, String>();
            respMap.put("accessid", accessId);
            respMap.put("policy", encodedPolicy);
            respMap.put("signature", postSignature); // 签名
            respMap.put("dir", dir);
            respMap.put("host", host);
            respMap.put("expire", String.valueOf(expireEndTime / 1000));

            JSONObject jasonCallback = new JSONObject();
            // jasonCallback.put("callbackUrl", callbackUrl);
            jasonCallback.put("callbackBody",
                    "filename=${object}&size=${size}&mimeType=${mimeType}&height=${imageInfo.height}&width=${imageInfo.width}");
            jasonCallback.put("callbackBodyType", "application/x-www-form-urlencoded");
            String base64CallbackBody = BinaryUtil.toBase64String(jasonCallback.toString().getBytes());
            respMap.put("callback", base64CallbackBody);

            return R.ok().put("data", respMap);

        } catch (Exception e) {
            System.out.println(e.getMessage());
            return R.error();
        } finally {
            ossClient.shutdown();
        }
    }
}

3.测试

image-20240414112556827

8.通过前端上传图片到OSS
1.将上传文件工具类放到 src/components下

image-20240414113130659

2.policy.js 向签名直传服务发送请求,获取签名(部署的时候注意修改)

image-20240414113456945

3.singleUpload.vue 就是一个上传文件的组件,修改action

image-20240414113958137

4.启动前后端项目测试

image-20240414114456217

5.src/views/modules/commodity/brand-add-or-update.vue 整合上传文件的控件
1.引入导出上传文件的控件

image-20240414115513519

2.使用控件

image-20240414115839061

3.查看效果

image-20240414115859829

4.上传出现跨域问题

image-20240414120134558

6.上传文件跨域解决
1.上传文件之前通过浏览器向后端发送请求,获取签名
  • 首先调用beforeUpload方法

  • 然后调用policy方法,就是policy.js的方法

image-20240414133848724

  • policy.js的方法通过浏览器向后端发送请求获取签名,此时出现跨域

image-20240414134148637

2.从renren-fast模块找到io/renren/config/CorsConfig.java的配置文件,放到后端项目即可解决第一个跨域

image-20240414121549866

3.重启后端,再次测试,还是有跨域问题

image-20240414130555641

4.第二个跨域问题分析

从浏览器报错中可以看到这次是向oos发送请求,进行保存文件的,也是满足跨域条件

5.在阿里云OSS解决跨域

网址:https://oss.console.aliyun.com/bucket/oss-cn-beijing/sunliving/data-security/cors

image-20240414135739013

image-20240414135907502

6.再次测试,成功!

image-20240414135948647

image-20240414140246723

7.使用前端工具类进行文件上传步骤梳理
1.保证后端传递的签名json对象使用data命名

image-20240414141202639

2.修改 policy.js 的url为后端返回签名的接口

image-20240414141430133

3.修改 el-upload 标签的action为 http:// + bucket + endpoint

image-20240414141613112

4.两个跨域问题
  1. 前端向后端签名接口发送请求
  2. 前端向OSS发送请求存储图片
9.品牌管理列表显示logo图片
1.目前插入数据,显示的是url
1.示意图

image-20240414142356141

2.通过访问这个url可以下载图片

image-20240414142457068

2.使用插槽机制显示图片
        <!-- 使用插槽机制来显示图片 -->
        <template slot-scope="scope">
          <img
            :src="scope.row.logo"
            style="width: 80px;"
          >
        </template>

image-20240414144846826

3.结果展示

image-20240414144903146

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/630167.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一文读懂云渲染与离线渲染的关系是什么

云渲染和离线渲染是什么关系呢&#xff1f;在渲染过程中经常会有人听到云渲染、离线渲染&#xff0c;然而两者的关系却有很多人都不清楚&#xff0c;下面一起来简单看看两者之间的关系吧。 1、渲染目的和过程&#xff1a; - 离线渲染&#xff1a;通常用于创建高质量的静态图像…

每日复盘-20240515

仅用于记录当天的市场情况&#xff0c;用于统计交易策略的适用情况&#xff0c;以便程序回测 短线核心&#xff1a;不参与任何级别的调整&#xff0c;采用龙空龙模式 一支股票 10%的时候可以操作&#xff0c; 90%的时间适合空仓等待 国联证券 (1)|[9:25]|[133765万]|31.12 一…

单位个人怎样向报社的报纸投稿?

作为一名单位的信息宣传员,我肩负着每月定期在媒体上投稿发表文章的重任。然而,在投稿的道路上,我经历了不少波折和挫折。 一开始,我天真地以为只要将稿件发送到报社的投稿邮箱,就能轻松完成任务。然而,现实却远比我想象的复杂。邮箱投稿的竞争异常激烈,编辑们会在众多稿件中挑…

【35分钟掌握金融风控策略28】贷中模型体系策略应用

目录 贷中模型体系策略应用 信用模型体系和模型在策略中的应用 反欺诈模型体系和模型在策略中的应用 运营模型体系和模型在策略中的应用 贷中模型体系策略应用 在贷前模型部分已经讲过&#xff0c;贷前开发的很多模型是可以在贷中直接使用的。贷中与贷前的不同点在于&…

不相交集合的数据结构

一、不相交集合的操作 不相交集合的数据结构维护了一组不相交动态集的集合 &#xff0c;用集合中的某个成员作为代表标识集合。 集合在没有修改的情况下每次访问代表得到的答案是相同的&#xff0c;此外在其它一些应用中&#xff0c;可能按照规定选择集合的代表&#xff0c;例如…

es 分词器(五)之elasticsearch-analysis-jieba 8.7.0

es 分词器&#xff08;五&#xff09;之elasticsearch-analysis-jieba 8.7.0 今天咱们就来讲一下es jieba 8.7.0 分词器的实现&#xff0c;以及8.x其它版本的实现方式&#xff0c;如果想直接使用es 结巴8.x版本&#xff0c;请直接修改pom文件的elasticsearch.version版本号即可…

光栅化技术在AI去衣应用中的创新探索

引言&#xff1a; 随着计算机视觉和人工智能技术的飞速发展&#xff0c;AI去衣技术逐渐走进公众视野。这一技术以其独特的应用前景和技术挑战引起了广泛的关注。在实现衣物去除的同时保持图像质量的关键技术之一&#xff0c;便是光栅化技术。本文将深入探讨光栅化技术在AI去衣中…

软考中级-软件设计师 (十一)标准化和软件知识产权基础知识

一、标准化基础知识 1.1标准的分类 根据适用的范围分类&#xff1a; 国际标准指国际化标准组织&#xff08;ISO&#xff09;、国际电工委员会&#xff08;IEC&#xff09;所制定的标准&#xff0c;以及ISO所收录的其他国际组织制定的标准。 国家标准&#xff1a;中华人民共和…

康谋产品 | 车载以太网:智能汽车通信的加速器

摘要&#xff1a; 在智能汽车技术飞速发展的今天&#xff0c;车载网络已成为汽车智能化的重要基础。想象一下&#xff0c;如果汽车的每个部件都是一个信息节点&#xff0c;它们之间需要即时、准确地交换大量数据&#xff0c;那么一个高速、高效的网络就成为了必不可少的基础设…

SFTPGO 整合minio AD群组 测试 |sftpgo with minio and ldap group test

SFTP-GO 研究 最近在测试sftpgo&#xff0c;发现中文的资料比较少&#xff0c;在企业中很多存储开始支持S3&#xff0c;比如netapp 于是想尝试把文件服务器换成sftpgoS3的存储&#xff0c;sftp go和AD 群组的搭配测试比较少 自己测试了一把&#xff0c;觉得还是没有server-u的A…

【计算机毕业设计】springboot反诈科普平台的设计与实现

相比于以前的传统手工管理方式&#xff0c;智能化的管理方式可以大幅降低反诈科普平台的运营人员成本&#xff0c;实现了反诈科普平台的 标准化、制度化、程序化的管理&#xff0c;有效地防止了反诈科普平台的随意管理&#xff0c;提高了信息的处理速度和精确度&#xff0c;能够…

MYSQL-9.问题排查

问题排查的思路与方向 问题排查思路 分析问题&#xff1a;根据理论知识经验分析问题&#xff0c;判断问题可能出现的位置或可能引起问题的原因&#xff0c;将目标缩小到一定范围&#xff1b;排查问题&#xff1a;基于上一步的结果&#xff0c;从引发问题的“可疑性”角度出发…

Vue3+ts(day06:路由)

学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/frontlearningNotes 觉得有帮助的同学&#xff0c;可以点心心支持一下哈&#xff08;笔记是根据b站上学习的尚硅谷的前端视频【张天禹老师】&#xff0c;记录一下学习笔记&#xff0c;用于自己复盘&#xff0c;有需要学…

基于Pytorch深度学习神经网络MNIST手写数字识别系统源码(带界面和手写画板)

第一步&#xff1a;准备数据 mnist开源数据集 第二步&#xff1a;搭建模型 我们这里搭建了一个LeNet5网络 参考代码如下&#xff1a; import torch from torch import nnclass Reshape(nn.Module):def forward(self, x):return x.view(-1, 1, 28, 28)class LeNet5(nn.Modul…

【传知代码】VRT: 关于视频修复的模型(论文复现)

前言&#xff1a;随着数字媒体技术的普及&#xff0c;制作和传播视频内容变得日益普遍。但是&#xff0c;视频中由于多种因素&#xff0c;例如传输、存储和录制设备等&#xff0c;经常出现质量上的问题&#xff0c;如图像模糊、噪声干扰和低清晰度等。这类问题对用户的体验和观…

数学建模——农村公交与异构无人机协同配送优化

目录 1.题目 2.问题1 1. 问题建模 输入数据 ​编辑 2. 算法选择 3.数据导入 3.模型构建 1. 距离计算 2. 优化模型 具体步骤 进一步优化 1. 重新定义问题 2. 变量定义 3. 优化目标 具体步骤 再进一步优化 具体实现步骤 1. 计算距离矩阵 2. 变量定义 3. 约束…

NVM安装及VUE创建项目的N种方式

VUE 参考官网&#xff1a;https://cli.vuejs.org/zh/guide/ 目录 NVM安装 1.卸载node.js 2.安装nvm ​编辑​ 3.配置 4.使用nvm安装node.js 5.nvm常用命令 创建VUE项目 1.使用vue init 创建vue2&#xff08;不推荐&#xff09; 2.使用vue create创建vue2和3&#xff…

(保姆级教程傻瓜式操作)树莓派--基于opencv实现人脸识别

前言 因为当时没有边实验边记录&#xff0c;所以这篇文章可能存在疏漏。不过很多地方我推荐了我参考过的博客或者视频&#xff0c;希望尽可能地解答您的疑惑&#xff0c;如果您仍有不懂的地方&#xff0c;欢迎评论&#xff0c;如果我知道答案&#xff0c;我会很乐意为您解答。 …

C++错题集(持续更新ing)

Day 1 一、选择题 解析&#xff1a; 在数字不会溢出的前提下&#xff0c;对于正数和负数&#xff0c;有&#xff1a; 1&#xff09;左移n位&#xff0c;相当于操作数乘以2的n次方&#xff1b; 2&#xff09;右移n位&#xff0c;相当于操作数除以2的n次方。 解析&#xff1a…