ホームページ  >  記事  >  Java  >  Javaweb はどのようにして完全な個人ブログ システムを構築するのでしょうか?

Javaweb はどのようにして完全な個人ブログ システムを構築するのでしょうか?

WBOY
WBOY転載
2023-04-21 21:55:071155ブラウズ

プロジェクトの基本プロセス

1.準備作業

pom.xmlに導入された依存関係パッケージ

<dependencies>
    <dependency>
        <groupId>org.thymeleaf</groupId>
        <artifactId>thymeleaf</artifactId>
        <version>3.0.12.RELEASE</version>
    </dependency>

    <!-- Servlet依赖包:官方提供的servlet标准 -->
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
        <!-- 开发编译时需要这个依赖包,运行时不需要 -->
        <scope>provided</scope>
    </dependency>

    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.49</version>
    </dependency>
    
	<!-- 数据绑定包,提供JAva对象与JSON数据格式进行序列化 -->
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.12.3</version>
    </dependency>
    
    <!--    引入单元测试框架,方便我们做测试    -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13.1</version>
    </dependency>
</dependencies>

シリアル化、逆シリアル化のためにJackson依存関係が導入されます操作
機能: データの整合性を確保するために、データとオブジェクトを相互に変換できるようにします

Jackson は、JSON 形式のデータを処理するために使用される Java クラス ライブラリです。非常に優れたパフォーマンスを備えており、JSON のシリアル化によく使用されます。 (オブジェクトを JSON 文字列に変換する) および逆シリアル化 (JSON 文字列を指定されたデータ型に変換する)

シリアル化および逆シリアル化の操作:

public class WebUtil {

    //判断是否登录,通过请求对象获取session,如果session存在且登录时
    // 保存的键为user,值是用户对象,这个数据存在,就表示已登录
    //返回user:已登录就返回session中保存的用户,未登录返回null
    public static User checkLogin(HttpServletRequest req){
        User user = null;
        //如果从tomcat保存的session的map数据结构中,获取session,false表示获取不到,返回null
        HttpSession session = req.getSession(false);
        if(session!=null){
            user = (User)session.getAttribute("user");
        }
        return user;
    }

    //这个对象可以使用单例
    private static ObjectMapper M = new ObjectMapper();

    //反序列化:转换一个输入流中包含的json字符串为一个java对象
    //使用泛型:传一个什么类型给我,就返回一个该类型的对象
    public static <T> T read(InputStream is,Class<T> clazz){
        try {
            return M.readValue(is,clazz);
        } catch (IOException e) {
            throw new RuntimeException("json反序列化出错",e);
        }
    }

    //序列化:将一个任意类型的java对象,转换为一个json字符串
    public static String write(Object o){
        try {
            return M.writeValueAsString(o);
        } catch (JsonProcessingException e) {
            throw new RuntimeException("json序列化出错",e);
        }
    }

2. データベース設計

1.必要なテーブル:

  • user (ユーザー テーブル)

  • acticle(記事テーブル)

2 . 対応するデータベースエンティティクラスの設計:

Javaweb はどのようにして完全な個人ブログ システムを構築するのでしょうか?

3. データベース接続ツール:

//数据库工具类:提供获取数据库连接,释放资源的统一代码
public class DBUtil {
    //静态变量,是类加载的时候初始化,只执行一次
    private static MysqlDataSource ds;
    //一个程序,连接一个数据库,只需要一个连接池,其中保存了多个数据库连接对象
    //1.获取连接池,内部使用,不开放
    private static DataSource getDataSource(){
        //ds类加载的时候,初始化为null,方法使用的时候,每次都判断一下
        if(ds==null){//判断为空,就创建及初始化属性
            ds=new MysqlDataSource();
            ds.setURL("jdbc:mysql://127.0.0.1:3306/blog");
            ds.setUser("root");
            ds.setPassword("010124");
            ds.setUseSSL(false);//不安全连接,如果不设置,也不影响,只是有警告
            ds.setCharacterEncoding("UTF-8");
        }
        return ds;
    }

    //2.获取数据库连接对象:开放给外部的jdbc代码使用
    public static Connection getConnection(){
        try {
            return getDataSource().getConnection();
        } catch (SQLException e) {
            throw new RuntimeException("获取数据库连接出错,可能是url,账号密码写错了",e);
        }
    }
    
    //3.释放资源
    //查询操作需要释放三个资源,更新操作(插入,修改,删除)只需要释放前两个资源
    public static void close(Connection c, Statement s, ResultSet r){
        try {
            if(r!=null) r.close();
            if(s!=null) s.close();
            if(c!=null) c.close();
        } catch (SQLException e) {
            throw new RuntimeException("释放数据库资源出错",e);
        }
    }

    //提供更新操作方便的释放资源功能
    public static void close(Connection c, Statement s){
        close(c,s,null);
    }

    public static void main(String[] args) {
        System.out.println(getConnection());
    }
}

4. ユーザーテーブルと記事テーブルのCRUD操作(Daoクラス) :

Javaweb はどのようにして完全な個人ブログ システムを構築するのでしょうか?

#3. フロントエンド ページを準備する

1. 適切なフロントエンド静的ページを webapp ディレクトリにデプロイする前に記述します

2. ajax のカプセル化:

フロントエンドとバックエンドの対話では、データ対話に ajax を使用する必要があります
以前にカプセル化された ajax 関数をコピーして、別の js に配置します。後続の使用のためにファイルを作成します

function ajax(args){//var ajax = function(){}
    let xhr = new XMLHttpRequest();
    // 设置回调函数
    xhr.onreadystatechange = function(){
        // 4: 客户端接收到响应后回调
        if(xhr.readyState == 4){
            // 回调函数可能需要使用响应的内容,作为传入参数
            args.callback(xhr.status, xhr.responseText);
        }
    }
    xhr.open(args.method, args.url);
    //如果args中,contentType属性有内容,就设置Content-Type请求头
    if(args.contentType){//js中,if判断,除了判断boolean值,还可以判断字符串,对象等,有值就为true
        xhr.setRequestHeader("Content-Type", args.contentType);
    }
    //如果args中,设置了body请求正文,调用send(body)
    if(args.body){
        xhr.send(args.body);
    }else{//如果没有设置,调用send()
        xhr.send();
    }
}

3. クラスを設計します: フロントエンドの Ajax コールバックに戻るために使用します

//设计一个类,用于返回给前端ajax回调
public class JsonResult {
    private boolean ok;//表示执行一个操作是否成功
    private Object data;//操作成功,且是一个查询操作,需要返回一些数据给前端

	//同样省略getter、setter和toString
}

4. フロントエンドの必要な関数と一致するサーブレットを実装します

Javaweb はどのようにして完全な個人ブログ システムを構築するのでしょうか?

5. プロジェクトの難しさ

  • ユーザーはログインせずにホームページのコンテンツにアクセスすることができず、ログイン画面にリダイレクトされることに気づきました。次に、ユーザーがログインせずにインターフェイスにアクセスすることも違法です。また、ログイン ページにリダイレクトする必要があります。

  • 記事が公開された後、新しい記事を作成する必要があります。全文を表示 マークダウン形式のデータを HTML に変換するには

  • # ログインに成功した後、セッションを作成し、後で使用するためにユーザー情報を保存する必要もあります

以上がJavaweb はどのようにして完全な個人ブログ システムを構築するのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。