美文网首页
[JavaWeb - 1] Hello World

[JavaWeb - 1] Hello World

作者: 做梦枯岛醒 | 来源:发表于2018-01-02 14:27 被阅读66次

时间轴:
17年12月首次发表
18年12月第一次更新

0.准备

我们使用SpringBoot进行JavaWeb开发,首先准备的东西是IDEA,下面的操作都是在IDEA安装好的基础上进行的,所以如果参考本文章新建工程的话,请先装好IDEA,本篇文章简单介绍一些简单的JavaWeb的操作,对于有些专业名词解释,或者小小小小小白入门的文章,以后会考虑增加一篇,然后在下一篇,我们将正式认识SpringBoot。

目录:
1.新建Web工程
2.配置环境
3.测试Jsp
4.测试Servlet
5.测试数据库

1.新建工程

打开IDEA


一路安装显示的界面 启动界面 新建页面

点击新建工程


然后就进入了这个页面

首先我们看右上角的红色,提示No SDK,那么这里其实是让我们配置jdk,我们把安装好的jdk路径给它,来new一个


配置JDK

这样子就有了jdk

然后我们新建Web工程,选中Web Application,点击next


新建Web工程

起个名字放个目录

工程

点击Finish我们的工程就算建立完成了。

这是新工程的页面

出现新工程页面,Tip的话直接把Show Tips 的小对勾去掉关掉就行了。

2.配置环境

接下来我们配置Web容器,选择File->setting->Application Servers,三步Application Servers 点击绿色添加按钮,选择Tomcat Server


image.png

小弹窗,添加Tomcat路径,(Tomcat可以去官网下载,下载后解压放在一个地方就可以用了),如果容器都已经配置好的,可以跳过这一步


Tomcat路径

确定之后我们的Tomcat也就配置好了。然后它自动导入了tomcat的一些文件,点击Apply再点OK,这一步就完成了。

接下来我们回到主界面,点击右上角的带蓝点点的图标 配置 在出现的页面中选择Modules,然后选择Dependencies,然后点击绿色小按钮添加Library 配置

选择你刚才弄好的Application Server


配置
然后添加到Lib里,现在显示如下
image.png

Apply->ok,回到主界面。
此时侧边目录External Libraries也多了Tomcat


目录
【以后,每次通过蓝点点图标配置依赖或者maven配置依赖,如果成功了,都会在这里看到相应的第三方库,可以用来检查你有没有添加好依赖,当然还有别的界面也可以看,以后再说】

3.测试Jsp

新建的Web工程一般都会有一个默认的jsp(在web目录下,如图所示),我们选择index.jsp,右键运行(注意看图,我的JSP文件内容被我改过,所以如果你运行后得不到下图的结果也是正常的,一般是点击运行后,没什么大问题会自动弹出默认浏览器,请仔细留意下浏览器地址栏的网址,我们以后是需要通过这种网址访问的)


index

可能初次运行还需要给个java环境,就把jdk目录放进去就行了。
【当然不需要可以直接跳过】
以后运行就可以在右上角点击绿色按钮了。


运行
点击绿色按钮后,会出现四种选项,优先使用第四种,其他的以后再介绍。
启动

这个就是我们的结果啦!


Hello World

4.测试Servlet

Servlet

新建一个Servlet,自己取个名字。
内容如下

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.IOException;
import java.io.PrintWriter;

@WebServlet(name = "TestServlet",urlPatterns = {"/TestServlet"})
public class TestServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        PrintWriter printWriter  = response.getWriter();
        printWriter.print("Hello Servlet");
    }
}

修改index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
  <title>Jsp测试</title>
</head>
<body>
<a href="TestServlet">Hello World</a>
</body>
</html>

然后运行一下。

出现一个警告,虽然是警告,但是已经影响了运行


问题

解决方案就是选择Project Structure(蓝点点图标)


解决

设置一个新版本的level,尽量选择与jdk匹配的吧,应该也没什么道理,但是这样就好了。

点击运行


image.png
image.png

成功!

5.测试数据库[如果还没深入学习数据库,可以跳过此部分,等学会了再回来看]

我们这里用的是mysql数据库,安装时采用xampp,因为我要用到phpmyadmin来管理数据库,具体安装不在这里多说。我们直接看servlet链接数据库,也就是Jdbc链接。

建立测试数据库并打开。

在这之前另一篇blog也写了mysql的一些踩坑,这里再整理一下。
首先我们要用mysql,必须导入lib。

打开project Structure(蓝点点图标)

我们选择libraries,从maven导入mysql


导入包

搜索。

image.png
选第一个,一路ok。
这个东西理论上可以自己生成一个WEB-INF下的lib,如果没有的话,参考https://www.jianshu.com/p/1cec18a146e3

下面写jdbc的代码,修改TestServlet。

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.IOException;
import java.io.PrintWriter;
import java.sql.*;


@WebServlet(name = "TestServlet",urlPatterns = {"/TestServlet"})
public class TestServlet extends HttpServlet {

    //JDBC数据库访问URL jdbc:mysql://localhost/数据库名字
    private static final String DB_URL = "jdbc:mysql://localhost/rfid?serverTimezone=UTC";
    private static Connection conn;
    private static Statement stmt;


    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            //设置响应内容类型
       req.setCharacterEncoding("utf-8");
       resp.setContentType("text/html;charset=utf-8");
       resp.setCharacterEncoding("utf-8");

        PrintWriter out  = response.getWriter();
        out.print("Hello Servlet");

        try
        {
            //初始化JDBC驱动
            Class.forName("com.mysql.cj.jdbc.Driver");
            //链接数据库
            conn = DriverManager.getConnection(DB_URL,"root","");
            //执行一个查询
            stmt = conn.createStatement();
            String sql = "SELECT * FROM books";
            ResultSet rs = stmt.executeQuery(sql);

            //取得结果集
            while(rs.next()){
                //Retrieve by column name
                int id  = rs.getInt("id");
                String isbn = rs.getString("isbn");
                String name = rs.getString("name");
                int status = rs.getInt("status");

                //Display values
                out.print("ID: " + id);
                out.print(", Age: " + isbn);
                out.print(", First: " + name);
                out.println(", Last: " + status);
            }
        } catch (ClassNotFoundException | SQLException e)
        {
            e.printStackTrace();
        }

    }
}

这样运行起来就OK啦!

好啦,这篇文章就到这里啦!

文章集合
JavaWeb - 2 SpringBoot新工程

相关文章

网友评论

      本文标题:[JavaWeb - 1] Hello World

      本文链接:https://www.haomeiwen.com/subject/fuffnxtx.html