SpringMVC框架整合(搭建框架——测试——上传图像) 2

简介: SpringMVC框架整合(搭建框架——测试——上传图像)

带参数传值的四种方法

向前端页面跳转需要Model(数据)和View(页面)

1.ModelAndView方式传值
@RequestMapping("/hello02")
    public ModelAndView hello02(ModelAndView modelAndView){
        modelAndView.setViewName("hello01.jsp");
        modelAndView.addObject("username","pp");
        return modelAndView;
    }
2.Model方式传值
@RequestMapping("/hello03")
    public String hello03(Model model){
        model.addAttribute("username","ppp");
        return "hello01.jsp";
    }
3.HttpServletRequest方式传值
@RequestMapping("/hello04")
    public String hello04(HttpServletRequest request){
        request.setAttribute("username","pppp");
        return "hello01.jsp";
    }
4.Map方式传值
@RequestMapping("/hello05")
    public String hello05(Map map){
        map.put("username","ppppp");
        return "hello01.jsp";
    }

其实四种传值方式本质上都是转发,比较常用的是Model方式。

重定项

重定项在SpringMVC中非常的简单就是在return后面添加redirect:

    @RequestMapping("/hello05")
    public String hello05(Map map){
        map.put("username","ppppp");
        return "redirect:/login.jsp";
    }

前端向后端传值

前端传值一般使用表单提交

前端传值页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<body>
<h2>Hello World!</h2>
<form action="/hello/hello03" method="post">
    用户名:<input type="text" name="username">
    密码:<input type="text" name="pwd">
    <br>
    <input type="submit" value="提交">
</form>
</body>
</html>

后端接收

可以直接把name值写在方法参数里面(不推荐使用

@RequestMapping("/hello03")
    public String hello03(String username,String pwd,Model model){
        System.out.println("用户名:"+username+"密码:"+pwd);
        model.addAttribute("username","ppp");
        return "hello01.jsp";
    }

也可以创建个实体类接收,前提实体类里要有这些属性(推荐使用

@RequestMapping("/hello03")
    public String hello03(User user,Model model){
        System.out.println("用户名:"+user.getUsername()+"密码:"+user.getPwd());
        model.addAttribute("username","ppp");
        return "hello01.jsp";
    }

网页报错跳转

应用场景,网页的404页面或者500页面

网页中只要有错误就会跳转到你设置的那个错误页面

这个是在本类里面的错误跳转,RuntimeException表示运行时的错误,可以改变

@ExceptionHandler(RuntimeException.class)
    public String error(Exception e){
        System.out.println(e.getMessage());
        return "error.jsp";
    }

写在SpringMVC配置文件表示这个项目中的错误都跳转,RuntimeException表示运行时的错误,可以改变

<!--有错误时跳转的页面-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
        <property name="exceptionMappings">
            <props>
                <prop key="java.lang.RuntimeException">error.jsp</prop>
            </props>
        </property>
    </bean>

Ajax方式

发起Ajax请求

发起Ajax请求只需要在方法上面添加@ResponseBody注解就可以实现

这样return返回的就不再是页面而是数据,前端发起Ajax请求就能获取到

    @RequestMapping("/hello06")
    @ResponseBody
    public String hello06(){
        User user=new User();
        user.setUsername("牛牛");
        user.setPwd("123");
        String result= JSON.toJSONString(user);
        return result;
    }

发起Ajax请求直接赋值

 @RequestMapping(value = "/hello07/{username}/{pwd}",produces = {"text/html;charset=utf-8"})
    @ResponseBody
    public String hello07(@PathVariable("username") String username,
                          @PathVariable("pwd") String pwd){
        return username+pwd;
    }

效果:

虽然这种方式很方便,但是不安全,用户也不会在这里直接输入,(目前不常用

上传图片

前端页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>上传页面</title>
</head>
<body>
    <form action="/hello/upload" method="post" enctype="multipart/form-data">
        <input type="text" name="username">
        <br>
        <input type="file" name="photo">
        <br>
        <input type="submit" value="提交">
    </form>
</body>
</html>

后端代码

@RequestMapping("/upload")
    public String upload(String username,MultipartFile photo,HttpServletRequest request){
        String fileType=photo.getOriginalFilename();//获取文件名
        int index=fileType.lastIndexOf(".");//获取文件后缀有几位
        fileType=fileType.substring(index);截取后缀
        String path=request.getSession().getServletContext().getRealPath("static"+ File.separator+"uploadfiles");//拼接地址
        long filename=System.currentTimeMillis();//获取当前时间时间戳
        File file=new File(path+"\\"+filename+fileType);//上传的地址
        System.out.println(path+"\\"+filename+fileType);//打印地址
        try {
            photo.transferTo(file);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return "上传成功";
    }

获取时间戳,将图片名称改为时间戳传入tomcat容器

输出:

可以通过此地址在网页里查询到刚刚上传的图片


拦截器

SpringMVC中写入拦截器

<mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/hello/**"/>
            <mvc:exclude-mapping path="/hello/hello04"/>
            <bean class="com.interceptor.LoginInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

解释:


<mvc:mapping path="/hello/**"/>拦截的地址

<mvc:exclude-mapping path="/hello/hello04"/>规定不拦截的地址

<bean class="com.interceptor.LoginInterceptor"></bean>调用拦截的类

拦截器类方法编写

package com.interceptor;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("preHandle");
        String username= request.getParameter("username");
        //判断是否有username
        if (null==username||"".equals(username)){
            response.sendRedirect("/index.jsp");
            return false;
        }
        return true;
    }
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("afterCompletion:页面没加载之前");
    }
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion:全部执行完毕后执行");
    }
}

应用场景:一般在登录页面

(完)

相关文章
|
3天前
|
算法 数据安全/隐私保护 计算机视觉
基于FPGA的图像双线性插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
本项目展示了256×256图像通过双线性插值放大至512×512的效果,无水印展示。使用Matlab 2022a和Vivado 2019.2开发,提供完整代码及详细中文注释、操作视频。核心程序实现图像缩放,并在Matlab中验证效果。双线性插值算法通过FPGA高效实现图像缩放,确保质量。
|
3天前
|
人工智能 自然语言处理 测试技术
AxBench:斯坦福大学推出评估语言模型控制方法的基准测试框架
AxBench 是由斯坦福大学推出,用于评估语言模型可解释性方法的基准测试框架,支持概念检测和模型转向任务,帮助研究者系统地比较不同控制技术的有效性。
31 5
AxBench:斯坦福大学推出评估语言模型控制方法的基准测试框架
|
25天前
|
小程序 前端开发 关系型数据库
uniapp跨平台框架,陪玩系统并发性能测试,小程序源码搭建开发解析
多功能一体游戏陪练、语音陪玩系统的开发涉及前期准备、技术选型、系统设计与开发及测试优化。首先,通过目标用户分析和竞品分析明确功能需求,如注册登录、预约匹配、实时语音等。技术选型上,前端采用Uni-app支持多端开发,后端选用PHP框架确保稳定性能,数据库使用MySQL保证数据一致性。系统设计阶段注重UI/UX设计和前后端开发,集成WebSocket实现语音聊天。最后,通过功能、性能和用户体验测试,确保系统的稳定性和用户满意度。
|
1月前
|
存储 测试技术 API
pytest接口自动化测试框架搭建
通过上述步骤,我们成功搭建了一个基于 `pytest`的接口自动化测试框架。这个框架具备良好的扩展性和可维护性,能够高效地管理和执行API测试。通过封装HTTP请求逻辑、使用 `conftest.py`定义共享资源和前置条件,并利用 `pytest.ini`进行配置管理,可以大幅提高测试的自动化程度和执行效率。希望本文能为您的测试工作提供实用的指导和帮助。
111 15
|
2月前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
522 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
2月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
90 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
1月前
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
6天前
|
JSON 前端开发 测试技术
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
47 10
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
|
4天前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
26 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
1月前
|
存储 测试技术 数据库
接口测试工具攻略:轻松掌握测试技巧
在互联网快速发展的今天,软件系统的复杂性不断增加,接口测试工具成为确保系统稳定性的关键。它如同“翻译官”,模拟请求、解析响应、验证结果、测试性能并支持自动化测试,确保不同系统间信息传递的准确性和完整性。通过Apifox等工具,设计和执行测试用例更加便捷高效。接口测试是保障系统稳定运行的第一道防线。

热门文章

最新文章