java:图片的上传,本地存储,回显

vv 

    @PostMapping("/upload")
    public Result upload(MultipartFile file, HttpServletRequest request) throws IOException {
//        拿取请求头中的token,解析到username
        String token=request.getHeader("Authorization");
        Map<String,Object> map=jwtutil.parsetoken(token);
        String username= map.get("username").toString();

//        给拿取到的图片进行加工,存入本地文件
        String aa = file.getOriginalFilename();
//        给图片给予唯一名字
        String filename= UUID.randomUUID().toString()+aa.substring(aa.lastIndexOf("."));
//         存入地址
        file.transferTo(new File("D:\\javakaifagongju\\图片\\"+filename));
//        获取老头像的名称,如果要更改新头像把老头像删除
        dfdfs dfdfs=mapper.select(username);
        System.out.println(dfdfs);
        String oldname=dfdfs.get头像名称();
        System.out.println(oldname);
        File file2=new File("D:\\javakaifagongju\\图片\\"+oldname);
        file2.delete();
//        url为老头像地址
        String url="http://localhost:8088/img/"+filename;
//        存入数据库
        mapper.updata(url,username,filename);
//        System.out.println(url);



        return Result.success("sd");


    }

上传图片的后端接口

@Configuration

public class webMvCConfig implements WebMvcConfigurer {
    @Autowired
    private Logininterceptor logininterceptor;

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/img/**").addResourceLocations("file:D:\\javakaifagongju\\图片\\");
    }

这个是静态资源映射,使Java可以访问D文件下下面的东西,映射路径为/img/**】

public class jwtutil {
//    Map为集合,一个集合两个类型的参数String和Object
    public static String grtToken(Map<String, Object> claims){
        return JWT.create().withClaim("claims",claims)
                .withExpiresAt(new Date(System.currentTimeMillis()+1000*60*60*12))
                .sign(Algorithm.HMAC256("qwer"));
    }
    public static Map<String,Object> parsetoken(String token){
        return JWT.require(Algorithm.HMAC256("qwer"))
                .build()
                .verify(token)
                .getClaim("claims")
                .asMap();
    }
}

这是token的生成和token的解析

@Component
@CrossOrigin
public class Logininterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String method = request.getMethod();	//输出 OPTIONS/GET/POST。。。
//如果是 OPTIONS 请求,让 OPTIONS 请求返回一个200状态码
        if (HttpMethod.OPTIONS.toString().equals(request.getMethod())) {
            response.setStatus(HttpServletResponse.SC_OK);
            return true;
        }

        String token =  request.getHeader("authorization");
        try{
            Map<String,Object> claims = jwtutil.parsetoken(token);
            return true;
        } catch (Exception e){
            response.setStatus(401);
            return false;
        }
    }
}

这个是验证前端是否携带token,如果携带放行,如果未携带拦截

public class webMvCConfig implements WebMvcConfigurer {
    @Autowired
    private Logininterceptor logininterceptor;

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/img/**").addResourceLocations("file:D:\\javakaifagongju\\图片\\");
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(logininterceptor).excludePathPatterns("/login","/hello1","/hello","/img/*");

    }
}

这个是在addInterceptors注册验证方法,excludePathPatterns是放行的接口

前端:

action为后端的接口,accept为允许的文件类型,on-success为成功回调的函数,headers为携带的请求头

<el-upload
  class="avatar-uploader"
  action="http://localhost:8088/upload"
  accept=".png,.jpg"
  :show-file-list="false"
  :on-success="handleAvatarSuccess"
  :headers="{'authorization':abc}"

  >
  <img v-if="imageUrl" :src="imageUrl" class="avatar">
  <i  class="el-icon-plus avatar-uploader-icon"></i>
  
</el-upload>
data() {
      return {
        activeIndex: '1',
        activeIndex2: '1',
        imageUrl: '',
        abc:this.$store.state.token
      };
    },

 vue2定义参数是在data()里的

这是登录成功后的操作

1.切换路由

2.将后端的token存入Vuex

else if(res.code==1){
        alert("登录成功")
         this.$router.push({path:"/login"})
         this.token=res.data
         console.log(this.token)
         this.$store.commit('set_token', this.token)
         const aaa= this.$store.state.token
         console.log(aaa)
        //  console.log(sad)
        
        
      }

这是Vuex的代码

import Vue from "vue";
import Vuex from "vuex";
Vue.use(Vuex)
const store = new Vuex.Store({
    state: {
        count:1,
        token:'',
        idCard:'',
    
    },
    mutations: {
        set_token(state, token) {
            state.token = token
            localStorage.token = token
        },
        //localStorage删除token
        del_token(state) {
            state.token = ''
            localStorage.removeItem('token')
        },
    
    }

  })
  export default store
import store from './stores/token'




new Vue({
  render: h => h(App),
  router:router,
  store:store,

注册进mian.js

头像回显:

前端:

在create拿取存入数据库的url


    
    async created(){
      const url=await first(this.abc)
      this.imageUrl=url
    },

axios接口

export function first(abc){
  return axios.get("http://localhost:8088/first",{headers:{'authorization':abc}}).then(res=>{
      // console.log(res.data.头像)
      return res.data.头像
    })
}

java:

    @GetMapping("/first")
    public dfdfs first(HttpServletRequest request){
        String token=request.getHeader("Authorization");
        Map<String,Object> map=jwtutil.parsetoken(token);
        String username= map.get("username").toString();
        return mapper.select(username);
    }

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是Java代码将文件上传至本地的示例: ```java import java.io.File; import java.io.IOException; import java.io.InputStream; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import javax.servlet.ServletException; import javax.servlet.annotation.MultipartConfig; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.Part; @WebServlet("/upload") @MultipartConfig public class FileUploadServlet extends HttpServlet { private static final long serialVersionUID = 1L; private static final String UPLOAD_DIR = "uploads"; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String applicationPath = request.getServletContext().getRealPath(""); String uploadFilePath = applicationPath + File.separator + UPLOAD_DIR; File fileUploadDirectory = new File(uploadFilePath); if (!fileUploadDirectory.exists()) { fileUploadDirectory.mkdirs(); } Part filePart = request.getPart("file"); String fileName = getFileName(filePart); String savePath = uploadFilePath + File.separator + fileName; InputStream inputStream = filePart.getInputStream(); Path filePath = Paths.get(savePath); Files.copy(inputStream, filePath); response.getWriter().println("File " + fileName + " has been uploaded successfully!"); } private String getFileName(final Part part) { final String partHeader = part.getHeader("content-disposition"); for (String content : partHeader.split(";")) { if (content.trim().startsWith("filename")) { return content.substring(content.indexOf('=') + 1).trim().replace("\"", ""); } } return null; } } ``` 解释: - `@WebServlet("/upload")` 注释指定了上传文件的路径。 - `@MultipartConfig` 注释指定了此 Servlet 支持多部分表单数据。 - `doPost()` 方法从请求中获取上传的文件并将其保存到指定的目录中。 - `getFileName()` 方法从请求头中获取文件名。 上传表单可以使用以下 HTML: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>File Upload Form</title> </head> <body> <form method="post" action="upload" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="Upload"> </form> </body> </html> ``` 此代码将上传的文件保存到 Web 应用程序目录的 `uploads` 文件夹中。可以根据需要更改上传文件的目录。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值