
🌐Hello World !
超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。请求和响应消息的头以ASCII形式给出;而消息内容则具有一个类似MIME的格式。这个简单模型是早期Web成功的有功之臣,因为它使开发和部署非常地直截了当。
| 状态代码 | 状态描述 | 说明 |
|---|---|---|
| 200 | OK | 客户端请求成功 |
| 302 | Found | 临时重定向 |
| 403 | Forbidden | 服务器收到请求,但是拒绝提供服务,服务器通常在响应正文中给出提供服务的原因 |
| 404 | Not Found | 请求的资源不存在,例如,输入了错误的URL |
| 500 | Internal Server Error | 服务器发生了不可预期的错误,导致无法完成客户端的请求 |
- get方式是直接请求URL时默认使用方式
- post是提交表单时常用的方式
Servlet体系结构中,除了实现Servlet接口,还可以继承GenericServlet或HttpServlet类,完成编写
Servlet API中最重要的是Servlet接口,所有的Servlet都会直接或间接与该接口发生联系,或是直接实现该接口,或继承实现该接口
| init (ServletConfig config) |
|---|
| ServletConfig getServletConfig () |
| service (ServletRequest req, ServletResponse,res) |
| String getServletInfo () |
| destroy () |
GenericServlet抽象类使编写Servlet变得更容易,它提供生命周期方法init和destroy的简单实现,编写一般的Servlet,只需要重写抽象的Servlet方法即可
HttpServlet是继承GenericServlet的基础上进一步的扩展
提供将要被子类化以创建适用于Web站点的HTTP Servlet的抽象类。HttpServlet的子类至少重写一个方法,该方法通过以下这些方法之一
| doGet | 如果Servlet支持HTTP GET请求 |
|---|---|
| doPost | 用于HTTP Post请求 |
| doPut | 用于HTTP PUT请求 |
| doDelete | 用于HTTP DELETE请求 |
1. 实现Servlet接口
- Servlet创建的第一种方式,实现接口Servlet
- 需要实现接口所有方法,比较麻烦
public class zuoye implements Servlet{ public zuoye() { super(); } @Override public int hashCode() { return super.hashCode(); } @Override public boolean equals(Object obj) { return super.equals(obj); } @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } @Override public String toString() { return super.toString(); } @Override protected void finalize() throws Throwable { super.finalize(); } @Override public void init(ServletConfig servletConfig) throws ServletException { } @Override public ServletConfig getServletConfig() { return null; } @Override public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException { } @Override public String getServletInfo() { return null; } @Override public void destroy() { } }2. 继承HttpServlet(推荐)
- 开发中、学习中常用
public class zuoye extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doGet(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { super.doPost(req, resp); } }
<!--<!DOCTYPE web-app PUBLIC-->
<!-- "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"-->
<!-- "http://java.sun.com/dtd/web-app_2_3.dtd" >-->
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1"
metadata-complete="true">
<!-- 起始页面-->
<welcome-file-list>
<!--起始页面路径-->
<welcome-file></welcome-file>
</welcome-file-list>
<!-- 注册Servlet-->
<servlet>
<!-- 名称-->
<servlet-name>helloServlet</servlet-name>
<!-- Servlet的全称类名路径-->
<servlet-class>com.woniu.servlet.HelloServlet</servlet-class>
<!-- 启动的优先级,越小优先级越高-->
<load-on-startup>1</load-on-startup>
</servlet>
<!-- 映射配置-->
<servlet-mapping>
<!-- 名称-->
<servlet-name>helloServlet</servlet-name>
<!-- 资源的匹配规则-->
<url-pattern>/hello</url-pattern>
</servlet-mapping>
<servlet>
<!-- Servlet命名-->
<servlet-name>helloService</servlet-name>
<!-- 填写Servlet完整的路径-->
<servlet-class>com.woniu.servlet.HelloService</servlet-class>
<!-- <load-on-startup>1</load-on-startup>-->
</servlet>
<!-- 请求映射标签,表示HTTP请求和Servlet类的对于关系-->
<servlet-mapping>
<!-- Servlet映射命名-->
<servlet-name>helloService</servlet-name>
<!-- Servlet映射路径-->
<url-pattern>/helloService</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>login</servlet-name>
<servlet-class>com.woniu.servlet.loginServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>login</servlet-name>
<url-pattern>/login</url-pattern>
</servlet-mapping>
</web-app>
- name:Servlet名字(可选)
- value:配置url路径,可以配置多个
- urlPatterns:配置url路径,和value作用一样,不能同时使用
- loadOnStartup:配置Servlet的创建的时机,如果是0或者正数启动程序时创建,如果是负数,则访问创建,数字越小优先级越高
- 可以和web.xml 共存同时生效
@WebServlet(urlPatterns = {"/bs","/bss"},loadOnStartup = 0)
request在Servlet中用来处理客户端请求需要用doGet或doPost对象
get请求
get请求的数据会放在URL之后,以?分割URL和传输数据,参数之间&相连
get方式明文传递,数据量小,不安全
效率高,浏览器默认使用get请求
请求对应 Servlet的方法是doGet
Post请求
post方法把提交的数据放在HTTP包的Body中
密文传递数据,数据量大,安全
效率相对没有GET高
请求对应 Servlet的方法是doPost
request主要方法
| 方法名 | 说明 |
|---|---|
| String getParameter(String name) | 根据表单组件名称获取提交数据 |
| void setCharacterEncodding(String charset) | 指定每个请求的编码 |
String getParameter(String name) //获取数据库中的参数数据
String username = req.getParameter("username"); //其中的这个username 是接受前台的参数
response对象用于响应客户请求并向客户端输出信息
response主要方法
| 方法名称 | 作用 |
|---|---|
| setHeader(name,value) | 设置响应信息头 |
| setContentType(String) | 设置响应文件类型,响应式的编码格式 |
| setCharacterEncoding(String) | 设置服务端响应内容编码格式 |
| getWriter() | 获取字符输出流 |
- Request 对象用于接收客户端浏览器提交的数据(浏览器向服务器发送请求)
- Response 对象的功能则是将服务器端的数据发送到客户端浏览器(服务器向浏览器发送回应)
案例:使用response对象向浏览器输出HTML内容,实现用户登录后,输出Login Success
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//request请求对象设置一次性编码
req.setCharacterEncoding("utf-8");
//获取用户请求发送的数据
String username = req.getParameter("username");
String password = req.getParameter("password");
System.out.println("提交的数据:" + username + "\t" + password);
// 响应数据给客户端
resp.setCharacterEncoding("utf-8"); //设置服务端的编码格式
resp.setHeader("Content-Type","text/html;charset=utf-8"); //设置浏览器端编码格式
resp.setContentType("text/html;charset=utf-8");
PrintWriter printWriter = resp.getWriter();
printWriter.println("register success!");
}
- 设置服务器响应的编码格式
- 设置客户端响应内容的文件类型及编码格式
resp.setCharacterEncoding("utf-8"); //设置服务端的编码格式
resp.setHeader("Content-Type","text/html;charset=utf-8"); //设置浏览器端编码格式
- 同时设置服务器端编码吗格式和客户端响应的文件类型及响应时的编码格式
resp.setContentType("text/html;charset=utf-8");
🌼 结语:创作不易,如果觉得博主的文章赏心悦目,还请——
点赞👍收藏⭐️评论📝

对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
是否可以在应用程序中包含的gem代码中知道应用程序的Rails文件系统根目录?这是gem来源的示例:moduleMyGemdefself.included(base)putsRails.root#returnnilendendActionController::Base.send:include,MyGem谢谢,抱歉我的英语不好 最佳答案 我发现解决类似问题的解决方案是使用railtie初始化程序包含我的模块。所以,在你的/lib/mygem/railtie.rbmoduleMyGemclassRailtie使用此代码,您的模块将在
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD
导读:随着叮咚买菜业务的发展,不同的业务场景对数据分析提出了不同的需求,他们希望引入一款实时OLAP数据库,构建一个灵活的多维实时查询和分析的平台,统一数据的接入和查询方案,解决各业务线对数据高效实时查询和精细化运营的需求。经过调研选型,最终引入ApacheDoris作为最终的OLAP分析引擎,Doris作为核心的OLAP引擎支持复杂地分析操作、提供多维的数据视图,在叮咚买菜数十个业务场景中广泛应用。作者|叮咚买菜资深数据工程师韩青叮咚买菜创立于2017年5月,是一家专注美好食物的创业公司。叮咚买菜专注吃的事业,为满足更多人“想吃什么”而努力,通过美好食材的供应、美好滋味的开发以及美食品牌的孵
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
我们目前正在为ROR3.2开发自定义cms引擎。在这个过程中,我们希望成为我们的rails应用程序中的一等公民的几个类类型起源,这意味着它们应该驻留在应用程序的app文件夹下,它是插件。目前我们有以下类型:数据源数据类型查看我在app文件夹下创建了多个目录来保存这些:应用/数据源应用/数据类型应用/View更多类型将随之而来,我有点担心应用程序文件夹被这么多目录污染。因此,我想将它们移动到一个子目录/模块中,该子目录/模块包含cms定义的所有类型。所有类都应位于MyCms命名空间内,目录布局应如下所示:应用程序/my_cms/data_source应用程序/my_cms/data_ty