JavaWeb初识 Response(例题) 跳转(重定向Response,转发Request)
服务器的请求无非就是一去一回:请求头、响应头(生命周期很短,一去一回就结束了)
先由客户端请求到服务器 再由服务发送请求到客户端
响应会发出相应的提示例如404 405等等(网上一找一大堆)搜索http响应代码
响应类型:如何制作点击就出现下载那?
网页相应代码不一定是下载内容,照片或者其他这个是不一定的。
之所以用Servlet 是因为可以在服务器中写逻辑
怎样书写 响应下载格式首先要去找你要上传的相对应格式
1.打开你的Tomcat 找到conf文件夹子
2.找到web.xml文件 查找你所相对的文件后缀
例如rar文件
示例代码:
io流代码
import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.OutputStream; public class OutputStreamUtil { public static void ouput(String file, OutputStream outputStream,long sleep) { try { FileInputStream fileInputStream = new FileInputStream(file); byte[] bytes = new byte[1024]; int len = 0; while ((len = fileInputStream.read(bytes)) != -1) { outputStream.write(bytes); outputStream.flush(); Thread.sleep(sleep); } outputStream.close(); } catch (Exception e) { e.printStackTrace(); } } }
方法说明代码
import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.OutputStream; import java.io.PrintWriter; @WebServlet("/XiXi") public class XiXi extends HttpServlet { @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //说明了类型客户端就会根据你的类型来呈现,如果是不认识的内容的话默认就是下载 resp.setContentType("text/html;charset=UTF-8"); //这个方法告诉浏览器响应的是什么类型 // text/html;charset=UTF-8 响应类型text文本格式,按照html输出,字符集是UTF8 PrintWriter printWriter = resp.getWriter(); //向外输出文本 printWriter.println("嘻嘻哈哈<hr>"); printWriter.close(); OutputStream outputStream = resp.getOutputStream(); //二进制的 字节无损输出,下载东西无损 } }
运用代码:
import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.*; @WebServlet("/hell2") public class Hello2 extends HttpServlet { @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { String psw = req.getParameter("psw"); int sw = 0; if (psw.equals("123456")) { sw = 0; } else if (psw.equals("123")) { sw = 200; } else { sw = 300; } if (sw >=0) { OutputStream outputStream = resp.getOutputStream(); resp.setContentType("application/x-rar-compressed"); resp.setContentLengthLong(new File("c:/1.rar").length()); //响应头下载长度setContentLengthLong resp.setHeader("Content-Disposition", "attachment;filename=1.rar");// //响应头下载名称,好处就是能说明格式下载完成后他能识别后缀进行显示 //响应头响应内容命名 OutputStreamUtil.ouput("c:/1.rar", resp.getOutputStream(), sw); } else { resp.setContentType("text/html;charset=UTF-8"); PrintWriter printWriter1 = resp.getWriter(); printWriter1.print("不好意思你没有权限下载"); printWriter1.close(); } } }
跳转:
重定向:加入我们有两个Servlet实例对象A,B 假如浏览器访问A、A说要跳转到B 他就会给浏览器说准备重定向,浏览器接受请求后再由浏览器跳转到B实例对象.
重定向是由浏览器进行跳转的(好处就是可以跳转别人的网站)
public class B extends HttpServlet { @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // resp.sendRedirect("A"); //resp.sendRedirect("URL");可以写本站地址,也可以写外站地址,外站地址需要加Http //重定向不是立即跳转的,只有响应信息到了浏览器,才会进行跳转 //这句代码无非就是设置了跳转信息配置,响应到了浏览器他才会进行跳转 try { Thread.sleep(5000); resp.sendRedirect("https://www.baidu.com");//定向到被人的Url //注意不要设置成死循环了A跳B、B在跳A\ //只能设置一次设置多了就会报错 } catch (InterruptedException e) { e.printStackTrace(); } } }
转发 就是不需要浏览器配合 例如浏览器访问A,A中有去B的转发那访问的就是B,
但是由于是每部执行所以浏览器不知道还以为你访问的是A
好处(唯一通道,只有转发可以转发到WEN-INF中去)
地址没有变
我们可以吧Jsp 或者其他处理页面文件放存放到 WEB-INF中
转发可以转发WEB-INF中的文件
转发操作是立即跳转
public class aa extends HttpServlet { @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { // 转发是Request对象进行操作的 RequestDispatcher requestDispatcher = req.getRequestDispatcher("bb"); requestDispatcher.forward(req, resp); //这句代码的意识是执行到这里立即跳到下一个页面去 } }
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
GIL 已经被杀死了么?
GIL 已经被杀死了么? 本文原创并首发于公众号【Python猫】,未经授权,请勿转载。 原文地址:https://mp.weixin.qq.com/s/8KvQemz0SWq2hw-2aBPv2Q 花下猫语: Python 中最广为人诟病的一点,大概就是它的 GIL 了。由于 GIL 的存在,Python 无法实现真正的多线程编程,因此很多人都把这视作 Python 最大的软肋。 PEP-554 提出后(2017年9月),大伙似乎看到了一线改善的曙光。然而,GIL 真的可以被彻底杀死么,如果可以的话,它会怎么实现呢,为什么等了一年多还没实现,仍需要我们等待多长时间呢? 英文 | Has the Python GIL been slain?【1】 作者 | Anthony Shaw 译者 | 豌豆花下猫 声明 :本文获得原作者授权翻译,转载请保留原文出处,请勿用于商业或非法用途。 2003 年初,Intel 公司推出了全新的奔腾 4 “HT” 处理器,该处理器的主频(译注:CPU 内核工作的时钟频率)为 3 GHz,采用了“超线程”技术。 在接下来的几年中,Intel 和 AMD 激烈...
- 下一篇
Java实现文本编辑时基于拼音输入的补全原型
所在源码库同上文, 尚未和上文的编辑器右侧的命令区集成. 代码由How to show autocomplete as I type in JTextArea?修改得来. 基本功能 英文输入至少一个匹配词典的字母后, 显示提示框 上下光标选中某提示项后按空格键自动替换 弹出提示框后, 如果继续键入, 提示框隐藏后, 根据新键入继续提示. 比如上面输入't'后提示"退出"和"粘贴"两项, 继续输入'c'后就只显示"退出" IDE和中文输入法的深度集成是必然趋势. 虽然现在第三方的中文输入法可以解决"输入"的基本功能, 但在IDE自动补全/智能提示功能日益成为开发效率提升的必需辅助功能的现今, 只有实现了中文输入法和IDE补全/提示的集成, 中文编程才能更接近实用. 这早已在易语言开发环境中实现, 期待早日看到开源项目实现类似功能. 源码简单说明 监听文本框的按键输入, 并准备弹出提示框: 文本区.addKeyListener(new KeyListener() { @Override public void keyTyped(KeyEvent e) { 随后显示提示(); } ... }...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8编译安装MySQL8.0.19
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- CentOS关闭SELinux安全模块