java学习--黑马SpringBoot3课程个人总结-2024-02-03

1.文章列表分页查询


bug1

 Cause: java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'state='草稿'
            
            and create_user=1
 ) tmp_count' at line 6

sql语句中少了一个and

在这里插入图片描述

类型转换错误:java.util.ArrayList cannot be cast to com.github.pagehelper.Page

pagehelper的配置问题
如果版本配置的不过会导致出现此问题

实现代码如下

Controller层代码
    @GetMapping
    public Result<PageBean<Article>> list(
            Integer pageNum,
            Integer pageSize,
            @RequestParam(required = false) Integer categoryId,
            @RequestParam(required = false)  String state
    )
    {
        PageBean<Article> pageBean= articleService.list(pageNum,pageSize,categoryId,state);
        return Result.success(pageBean);
    }
Service层代码
//条件分页列表查询
    @Override
    public PageBean<Article> list(Integer pageNum, Integer pageSize, Integer categoryId, String state) {
        //1.创建分页的pageBean对象
        PageBean<Article> pageBean = new PageBean<>();
        //2.开启分页查询
        PageHelper.startPage(pageNum,pageSize);
        //获取当前的用户ID
        Map<String ,Object> map=ThreadLocalUtil.get();
        Integer userId = (Integer) map.get("id");
        //3.调用mapper
        List<Article> articleList=articleMapper.list(userId,categoryId,state);
        //Page提供了方法,可以获取PageHelper分页查询后,当前的总记录数和当前页数据
        Page<Article> page= (Page<Article>) articleList;
        pageBean.setTotal(page.getTotal());
        pageBean.setItems(page.getResult());
        return pageBean;
    }
Mapper层代码
List<Article> list(Integer userId, Integer categoryId, String state);
动态sql
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.itheima.mapper.ArticleMapper">
<!--    动态sql-->
    <select id="list" resultType="com.itheima.pojo.Article">
        select * from big_event.article
        #    where标签可以让有条件就加where,没有条件就不加where,可以去掉第一个条件的 AND
        <where>
            <if test="categoryId!=null">
                category_id=#{categoryId}
            </if>
            <if test="state!=null">
               and  state=#{state}
            </if>
            and create_user=#{userId}
        </where>
    </select>
</mapper>
  • 创建了一个相同包名,相同类名的xml文件,用来实现动态SQL

在这里插入图片描述

引入了pageHelper依赖,这里要特别注意依赖的版本

<dependency>
      <groupId>com.github.pagehelper</groupId>
      <artifactId>pagehelper-spring-boot-starter</artifactId>
      <version>1.4.6</version>
    </dependency>

工具类pageBean

//分页返回结果对象
@Data
@NoArgsConstructor
@AllArgsConstructor
public class PageBean <T>{
    private Long total;//总条数
    private List<T> items;//当前页数据集合
}

2.文件上传的实现

@RestController
public class FileUploadController {

    @PostMapping("/upload")
    public Result<String> Upload(MultipartFile file) throws IOException{
        //把文件内容保存在本地磁盘上
        String originalFilename = file.getOriginalFilename();
        //保证文件的名字是唯一的,防止名字被覆盖
        String filename = UUID.randomUUID().toString() + originalFilename.substring(originalFilename.lastIndexOf("."));
        file.transferTo(new File("F:\\imgFiles\\" + filename));
        return Result.success("url访问地址");
    }
}

3.阿里云服务器OSS

在这里插入图片描述
在这里插入图片描述
在阿里云创建OSS的过程是在控制台寻找OSS对象存储服务

获取key
在这里插入图片描述
申请到AccessKey
在这里插入图片描述
在这里学习在java程序中使用OSS
首先添加依赖

   <!--    阿里云OSS依赖坐标-->
    <dependency>
      <groupId>com.aliyun.oss</groupId>
      <artifactId>aliyun-sdk-oss</artifactId>
      <version>3.15.1</version>
    </dependency>
<!--如果使用的是Java 9及以上的版本,则需要添加JAXB相关依赖。添加JAXB相关依赖示例代码如下:-->
    <dependency>
      <groupId>javax.xml.bind</groupId>
      <artifactId>jaxb-api</artifactId>
      <version>2.3.1</version>
    </dependency>
    <dependency>
      <groupId>javax.activation</groupId>
      <artifactId>activation</artifactId>
      <version>1.1.1</version>
    </dependency>
    <!-- no more than 2.3.3-->
    <dependency>
      <groupId>org.glassfish.jaxb</groupId>
      <artifactId>jaxb-runtime</artifactId>
      <version>2.3.3</version>
    </dependency>

查看endpoint
在这里插入图片描述
改代码中的这一部分
在这里插入图片描述

代码如下

public class Demo {

    public static void main(String[] args) throws Exception {
        // Endpoint以华东1(杭州)为例,其它Region请按实际情况填写。
        String endpoint = "https://oss-cn-beijing.aliyuncs.com";
        // 从环境变量中获取访问凭证。运行本代码示例之前,请确保已设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。
        //EnvironmentVariableCredentialsProvider credentialsProvider = CredentialsProviderFactory.newEnvironmentVariableCredentialsProvider();
        String ACCESS_KEY_ID="你自己的ID";
        String ACCESS_KEY_SECRET="你自己的密码";

        // 填写Bucket名称,例如examplebucket。
        String bucketName = "你刚创建的bucket名";
        // 填写Object完整路径,完整路径中不能包含Bucket名称,例如exampledir/exampleobject.txt。
        String objectName = "oipc.jpg";

        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(endpoint, ACCESS_KEY_ID,ACCESS_KEY_SECRET);

        try {
            // 填写字符串。
            String content = "Hello OSS,你好世界";

            // 创建PutObjectRequest对象。
            PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, objectName, new FileInputStream("你的文件路径"));
            // 如果需要上传时设置存储类型和访问权限,请参考以下示例代码。
            // ObjectMetadata metadata = new ObjectMetadata();
            // metadata.setHeader(OSSHeaders.OSS_STORAGE_CLASS, StorageClass.Standard.toString());
            // metadata.setObjectAcl(CannedAccessControlList.Private);
            // putObjectRequest.setMetadata(metadata);

            // 上传字符串。
            PutObjectResult result = ossClient.putObject(putObjectRequest);
        } catch (OSSException oe) {
            System.out.println("Caught an OSSException, which means your request made it to OSS, "
                    + "but was rejected with an error response for some reason.");
            System.out.println("Error Message:" + oe.getErrorMessage());
            System.out.println("Error Code:" + oe.getErrorCode());
            System.out.println("Request ID:" + oe.getRequestId());
            System.out.println("Host ID:" + oe.getHostId());
        } catch (ClientException ce) {
            System.out.println("Caught an ClientException, which means the client encountered "
                    + "a serious internal problem while trying to communicate with OSS, "
                    + "such as not being able to access the network.");
            System.out.println("Error Message:" + ce.getMessage());
        } finally {
            if (ossClient != null) {
                ossClient.shutdown();
            }
        }
    }

点击测试后


我们看到文件已经成功上传
在这里插入图片描述

4.将阿里云oss集成到自己的程序中

建立一个工具类
在这里先声明几个常量

在这里插入图片描述
在原本的测试代码中对参数进行了修改,让他可以动态的获取参数
在这里插入图片描述

    //因为我们最后返回的是一个图片的url地址,所以返回值为url
    public static String uploadFile(String objectName, InputStream inputStream) throws Exception {
        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(ENDPOINT, ACCESS_KEY_ID,ACCESS_KEY_SECRET);
        String url="";
        try {
            // 填写字符串。
            String content = "Hello OSS,你好世界";

            // 创建PutObjectRequest对象。
   PutObjectRequest putObjectRequest = new PutObjectRequest(BUCKET_NAME, objectName,inputStream);


            // 上传字符串。
            PutObjectResult result = ossClient.putObject(putObjectRequest);
            //url组成:https://bucket名称.区域节点/objectName
            url="https://"+BUCKET_NAME+"."+ENDPOINT.substring(ENDPOINT.lastIndexOf("/")+1)+"/"+objectName;
            return url;

修改原来的代码

    @PostMapping("/upload")
    public Result<String> Upload(MultipartFile file) throws Exception {
        //把文件内容保存在本地磁盘上
        String originalFilename = file.getOriginalFilename();
        //保证文件的名字是唯一的,防止名字被覆盖
        String filename = UUID.randomUUID().toString() + originalFilename.substring(originalFilename.lastIndexOf("."));
//        file.transferTo(new File("F:\\imgFiles\\" + filename));
        String url = AliOssUtil.uploadFile(filename, file.getInputStream());
        return Result.success(url);
    }
}

进行测试
在这里插入图片描述

成功上传文件
在这里插入图片描述

5.利用Redis实现令牌主动失效机制

我们发现在修改密码后,原来的令牌任然生效,这是不合理的。
实现思路如下
在这里插入图片描述
具体实现明天再做啦

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值