继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

毛哥的快乐生活(27) Servlet版新闻网站之接受用户页面请求

程序员大阳
关注TA
已关注
手记 357
粉丝 1.5万
获赞 1523

有哪些页面请求

之前已经分析过了,对于新闻网站来说,用户页面请求一共有3个:

  1. 普通用户请求查看新闻分类浏览页面
  2. 管理员登录页面
  3. 管理员发布新闻页面

构建请求地址

毛哥认真的想了下,不同的用户请求,可以通过不同的请求地址来体现,假如我们的项目名称为ServletNewsSite(Servlet版新闻网站),则请求地址可以设计为:

请求 请求地址
跳转查看新闻页面 gotoViewPage
跳转管理员登录页面 gotoLoginPage
跳转管理员发布新闻页面 gotoPublishPage

新建动态网站项目

使用eclipse新建一个动态网站项目(File-New-Dynamic Web Project) ,项目名称即为:ServletNewsSite。

新建Servlet用于接受用户请求

右键点击src目录,选择New-Class,新建一个Servlet类用于接受用户请求,代码如下:

/**
 * 新闻请求Servlet
 * @author maoge
 * @date 2019-05-05
 */
@WebServlet("/NewsServlet")
public class NewsServlet  extends HttpServlet{
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//解决上篇遗留的中文乱码问题
		resp.setContentType("text/html;charset=utf-8");
		PrintWriter out = resp.getWriter();
		out.println("hello from ServletNewsSite");
	}
}

所以这个servelt访问地址http://127.0.0.1:8080/ServletNewsSite/NewsServlet,解释下就是本机(127.0.0.1)8080端口(Tomcat默认运行端口)下ServletNewsSite项目内的NewsServlet路径对应的Servlet。

启动Tomcat服务器后,输入上面地址,页面果然显示:
图片描述

区分用户页面请求

刚刚讨论了,用户对页面的请求可以分为三类,我们可以通过传递不通的参数给NewsServlet区分请求的不同,所以结合Servlet设计请求地址为:

请求 请求地址 Servlet地址
跳转查看新闻页面 gotoViewPage http://127.0.0.1:8080/ServletNewsSite/NewsServlet?method=gotoViewPage
跳转管理员登录页面 gotoLoginPage http://127.0.0.1:8080/ServletNewsSite/NewsServlet?method=gotoLoginPage
跳转管理员发布新闻页面 gotoPublishPage http://127.0.0.1:8080/ServletNewsSite/NewsServlet?method=gotoPublishPage

也就是通过method参数来区分具体请求类型。

根据用户请求不同返回不同结果

这样就可以修改NewsServlet,以便于根据不同请求返回不同结果

@WebServlet("/NewsServlet")
public class NewsServlet  extends HttpServlet{
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//解决上篇遗留的中文乱码问题
		resp.setContentType("text/html;charset=utf-8");
		PrintWriter out = resp.getWriter();
		//获取用户请求地址中传递的method参数 
		String method=req.getParameter("method");
		if(method.equals("gotoViewPage")) {
			out.println("您请求的是新闻浏览页");
		}else if(method.equals("gotoLoginPage")){
			out.println("您请求的是登录页");
		}else if(method.equals("gotoPublishPage")){
			out.println("您请求的是新闻发布页");
		}else {
			out.println("404!您请求的页面不存在");
		}
	}
}

于是,浏览器地址请求gotoViewPage,Servlet会返回提示如下,同理访问不同地址,返回提示消息也不同。

图片描述

构建html网页模板

之前小范妹子已经将页面美工编码完毕,此时将只需要构建3个html页面模板,然后根据用户请求不同返回不同的模板内容即可。

需要注意页面动态内容部分加入注释,预留标志符号,便于后续动态替换内容。

package com.maoge.news.servelt;
/**
 * 新闻浏览页面html模板数据
 * @author maoge
 * @date 2019-05-05
 */
public class HtmlData {
	//新闻浏览页面模板
	public static String viewTemplate=
			"<!-- 新闻浏览页面 -->" + 
			"<html>" + 
			"<head>" + 
			"    <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\">" + 
			"    <title>新闻浏览页面</title>" + 
			"    <style>" + 
			"        body {" + 
			"            text-align: center;" + 
			"        }" + 
			"        #title-bar {" + 
			"            width: 600px;" + 
			"            margin: 0 auto;" + 
			"            border: 1px solid black;" + 
			"            height:64px;" + 
			"            line-height: 64px;" + 
			"            border-radius: 16px;" + 
			"            font-size:1.4em;" + 
			"        }" + 
			"        #title-bar span{" + 
			"            margin-right:24px;" + 
			"        }" + 
			"        #content-bar {" + 
			"            width: 800px;" + 
			"            margin: 24 auto;" + 
			"            min-height: 600px;" + 
			"            border: 1px solid black;" + 
			"            border-radius: 16px;" + 
			"        }" + 
			"" + 
			"        #content-bar ul li{" + 
			"            text-align: left;" + 
			"        }" + 
			"    </style>" + 
			"    <head>" + 
			"    <body>" + 
			"        <div id=\"title-bar\">" + 
			//导航栏可动态替换
			"@title-bar"+
			"        </div>" + 
			"        <div id=\"content-bar\">" + 
			"            <ul>" + 
			//新闻栏可动态替换
			"@content-bar"+
			"            </ul>" + 
			"        </div>" + 
			"    </body>" + 
			"</html>";
	//登录页面模板
	public static String loginTemplate=
			"<!-- 登录页面 -->" + 
			"<html>" + 
			"<head>" + 
			"    <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\">" + 
			"    <title>登录</title>" + 
			"    <style>" + 
			"        /*居中*/" + 
			"        body {" + 
			"            text-align: center;" + 
			"        }" + 
			"        #title-bar{" + 
			"            margin-top:24px;/*与窗口顶部有距离*/" + 
			"            font-size:2em;    /*大字体*/" + 
			"        }" + 
			"        #input-bar{" + 
			"            margin-top:64px;/*与标题栏有距离*/" + 
			"" + 
			"        }" + 
			"        #input-bar span{" + 
			"            display:inline-block;/*让span元素占据宽度*/" + 
			"            width:100px;/*控制文字长度,对齐*/" + 
			"         " + 
			"        }" + 
			"        #button-bar{" + 
			"            margin-top:64px;/*与标题栏有距离*/" + 
			"        }" + 
			"        #button-bar input[type=button]{" + 
			"            border:0px;/*去除按钮边框*/" + 
			"            border-radius: 4px;/*圆角边框*/" + 
			"            width:120px;" + 
			"            height: 32px;" + 
			"            background-color:cadetblue;/*背景色*/" + 
			"            color:white;/*字体颜色*/" + 
			"        }" + 
			"    </style>" + 
			"    <head>" + 
			"    <body>" + 
			"        <div id=\"title-bar\">欢迎登录XX讯息网</div>" + 
			"        <div id=\"input-bar\">" + 
			"            <span>用户名:</span><input type=\"text\"><br>" + 
			"            <span>密码:</span><input type=\"text\">" + 
			"        </div>" + 
			"        <div id=\"button-bar\">" + 
			"            <input type=\"button\" value=\"登录\">" + 
			"        </div>" + 
			"    </body>" + 
			"</html>";
	//新闻发布页模板
	public static String publishTemplate=
			"<!-- 新闻发布页面 -->" + 
			"<html>" + 
			"<head>" + 
			"    <meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\">" + 
			"    <title>发布新闻</title>" + 
			"    <style>" + 
			"        /*居中*/" + 
			"        body {" + 
			"            text-align: center;" + 
			"        }" + 
			"        #title-bar{" + 
			"            margin-top:24px;/*与窗口顶部有距离*/" + 
			"            font-size:2em;    /*大字体*/" + 
			"        }" + 
			"        #input-bar{" + 
			"            margin-top:64px;/*与标题栏有距离*/" + 
			"        }" + 
			"        #input-bar span{" + 
			"            display:inline-block;/*让span元素占据宽度*/" + 
			"            width:100px;/*控制文字长度,对齐*/" + 
			"        }" + 
			"        #input-bar textarea{" + 
			"            margin-top:24px;" + 
			"        }" + 
			"        #button-bar{" + 
			"            margin-top:64px;/*与标题栏有距离*/" + 
			"        }" + 
			"        #button-bar input[type=button]{" + 
			"            border:0px;/*去除按钮边框*/" + 
			"            border-radius: 4px;/*圆角边框*/" + 
			"            width:120px;" + 
			"            height: 32px;" + 
			"            background-color:cadetblue;/*背景色*/" + 
			"            color:white;/*字体颜色*/" + 
			"        }" + 
			"    </style>" + 
			"    <head>" + 
			"    <body>" + 
			"        <div id=\"title-bar\">发布新闻</div>" + 
			"        <div id=\"input-bar\">" + 
			"            <span>发布人:</span><input type=\"text\"><br>" + 
			"            <span>新闻类别:</span><input type=\"text\"><br>" + 
			"            <textarea rows=\"10\" cols=\"100\" placeholder=\"此处填写新闻内容\"></textarea>" + 
			"        </div>" + 
			"        <div id=\"button-bar\">" + 
			"            <input type=\"button\" value=\"确定发布\">" + 
			"        </div>" + 
			"    </body>" + 
			"</html>";
}

根据请求显示不同网页模板

修改Servlet,根据不同用户请求显示不同网页模板:

@WebServlet("/NewsServlet")
public class NewsServlet  extends HttpServlet{
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		//解决上篇遗留的中文乱码问题
		resp.setContentType("text/html;charset=utf-8");
		PrintWriter out = resp.getWriter();
		//获取用户请求地址中传递的method参数 
		String method=req.getParameter("method");
		if(method.equals("gotoViewPage")) {
			out.println(HtmlData.viewTemplate);
		}else if(method.equals("gotoLoginPage")){
			out.println(HtmlData.loginTemplate);
		}else if(method.equals("gotoPublishPage")){
			out.println(HtmlData.publishTemplate);
		}else {
			out.println("404!您请求的页面不存在");
		}
	}
}

此时再度请求三个页面,实际上已经实现了根据用户动态请求显示不同页面的效果。

图片描述

图片描述

图片描述

附:本章源码

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP