Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 www亚洲国产,德国一级毛片在线播放,色的视频网站

          整合營(yíng)銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          Servlet 數(shù)據(jù)庫(kù)訪問(wèn)

          教程假定您已經(jīng)了解了 JDBC 應(yīng)用程序的工作方式。在您開始學(xué)習(xí) Servlet 數(shù)據(jù)庫(kù)訪問(wèn)之前,請(qǐng)確保您已經(jīng)有適當(dāng)?shù)?JDBC 環(huán)境設(shè)置和數(shù)據(jù)庫(kù)。

          從基本概念下手,讓我們來(lái)創(chuàng)建一個(gè)簡(jiǎn)單的表,并在表中創(chuàng)建幾條記錄。

          創(chuàng)建數(shù)據(jù)庫(kù)表

          在測(cè)試數(shù)據(jù)庫(kù) TEST 中創(chuàng)建 Employees 表,請(qǐng)按以下步驟進(jìn)行:

          步驟 1:

          打開命令行提示符(Command Prompt),并更改進(jìn)入到安裝目錄,如下所示:

          C:\>
          C:\>cd Program Files\MySQL\bin
          C:\Program Files\MySQL\bin>
          

          步驟 2:

          登錄到數(shù)據(jù)庫(kù),如下所示:

          C:\Program Files\MySQL\bin>mysql -u root -p
          Enter password: ********
          mysql>
          

          步驟 3:

          在測(cè)試數(shù)據(jù)庫(kù) TEST 中創(chuàng)建 Employee 表,如下所示:

          mysql> use TEST;
          mysql> create table Employees
           (
           id int not null,
           age int not null,
           first varchar (255),
           last varchar (255)
           );
          Query OK, 0 rows affected (0.08 sec)
          mysql>
          

          創(chuàng)建數(shù)據(jù)記錄

          最后,在 Employee 表中創(chuàng)建幾條記錄,如下所示:

          mysql> INSERT INTO Employees VALUES (100, 18, 'Zara', 'Ali');
          Query OK, 1 row affected (0.05 sec)
           
          mysql> INSERT INTO Employees VALUES (101, 25, 'Mahnaz', 'Fatma');
          Query OK, 1 row affected (0.00 sec)
           
          mysql> INSERT INTO Employees VALUES (102, 30, 'Zaid', 'Khan');
          Query OK, 1 row affected (0.00 sec)
           
          mysql> INSERT INTO Employees VALUES (103, 28, 'Sumit', 'Mittal');
          Query OK, 1 row affected (0.00 sec)
           
          mysql>
          

          訪問(wèn)數(shù)據(jù)庫(kù)

          下面的實(shí)例演示了如何使用 Servlet 訪問(wèn) TEST 數(shù)據(jù)庫(kù)。

          // 加載必需的庫(kù)
          import java.io.*;
          import java.util.*;
          import javax.servlet.*;
          import javax.servlet.http.*;
          import java.sql.*;
           
          public class DatabaseAccess extends HttpServlet{
           
           public void doGet(HttpServletRequest request,
           HttpServletResponse response)
           throws ServletException, IOException
           {
           // JDBC 驅(qū)動(dòng)器名稱和數(shù)據(jù)庫(kù)的 URL
           static final String JDBC_DRIVER="com.mysql.jdbc.Driver"; 
           static final String DB_URL="jdbc:mysql://localhost/TEST";
           // 數(shù)據(jù)庫(kù)的用戶名與密碼,需要根據(jù)自己的設(shè)置
           static final String USER = "root";
           static final String PASS = "password";
           // 設(shè)置響應(yīng)內(nèi)容類型
           response.setContentType("text/html");
           PrintWriter out = response.getWriter();
           String title = "數(shù)據(jù)庫(kù)結(jié)果";
           String docType =
           "<!doctype html public \"-//w3c//dtd html 4.0 " + "transitional//en\">\n";
           out.println(docType +
           "<html>\n" +
           "<head><title>" + title + "</title></head>\n" +
           "<body bgcolor=\"#f0f0f0\">\n" +
           "<h1 align=\"center\">" + title + "</h1>\n");
           try{
           // 注冊(cè) JDBC 驅(qū)動(dòng)器
           Class.forName("com.mysql.jdbc.Driver");
           // 打開一個(gè)連接
           Connection conn = DriverManager.getConnection(DB_URL,USER,PASS);
           // 執(zhí)行 SQL 查詢
           Statement stmt = conn.createStatement();
           String sql;
           sql = "SELECT id, first, last, age FROM Employees";
           ResultSet rs = stmt.executeQuery(sql);
           // 展開結(jié)果集數(shù)據(jù)庫(kù)
           while(rs.next()){
           // 通過(guò)字段檢索
           int id = rs.getInt("id");
           int age = rs.getInt("age");
           String first = rs.getString("first");
           String last = rs.getString("last");
           // 輸出數(shù)據(jù)
           out.println("ID: " + id + "<br>");
           out.println(", Age: " + age + "<br>");
           out.println(", First: " + first + "<br>");
           out.println(", Last: " + last + "<br>");
           }
           out.println("</body></html>");
           // 完成后關(guān)閉
           rs.close();
           stmt.close();
           conn.close();
           }catch(SQLException se){
           // 處理 JDBC 錯(cuò)誤
           se.printStackTrace();
           }catch(Exception e){
           // 處理 Class.forName 錯(cuò)誤
           e.printStackTrace();
           }finally{
           // 最后是用于關(guān)閉資源的塊
           try{
           if(stmt!=null)
           stmt.close();
           }catch(SQLException se2){
           }
           try{
           if(conn!=null)
           conn.close();
           }catch(SQLException se){
           se.printStackTrace();
           }
           }
           }
          } 
          

          現(xiàn)在讓我們來(lái)編譯上面的 Servlet,并在 web.xml 文件中創(chuàng)建以下條目:

          ....
           <servlet>
           <servlet-name>DatabaseAccess</servlet-name>
           <servlet-class>DatabaseAccess</servlet-class>
           </servlet>
           
           <servlet-mapping>
           <servlet-name>DatabaseAccess</servlet-name>
           <url-pattern>/DatabaseAccess</url-pattern>
           </servlet-mapping>
          ....
          

          現(xiàn)在調(diào)用這個(gè) Servlet,輸入鏈接:http://localhost:8080/DatabaseAccess,將顯示以下響應(yīng)結(jié)果:

          <?xml version="1.0" encoding="UTF-8"?>
          <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
            <display-name>spring_mvc</display-name>
            <welcome-file-list>
              <welcome-file>index.html</welcome-file>
              <welcome-file>index.htm</welcome-file>
              <welcome-file>index.jsp</welcome-file>
              <welcome-file>default.html</welcome-file>
              <welcome-file>default.htm</welcome-file>
              <welcome-file>default.jsp</welcome-file>
            </welcome-file-list>
            
            
             <servlet>
            	<servlet-name>springmvc</servlet-name>
            	<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            	<init-param>
            		<param-name>contextConfigLocation</param-name>
            		<param-value>classpath:springmvc.xml</param-value>
            	</init-param>
            </servlet>
            
            <servlet-mapping>
            	<servlet-name>springmvc</servlet-name>
            	<url-pattern>*.action</url-pattern>
            </servlet-mapping>
            
            
          </web-app>

          eb框架是開發(fā)者在使用某種語(yǔ)言編寫Web應(yīng)用服務(wù)端項(xiàng)目時(shí)關(guān)于架構(gòu)的最佳實(shí)踐。很多Web框架是從實(shí)際的Web項(xiàng)目抽取出來(lái)的,僅和Web的請(qǐng)求和響應(yīng)處理有關(guān),形成一個(gè)基礎(chǔ),在開發(fā)別的應(yīng)用項(xiàng)目的時(shí)候則可以從這個(gè)剝離出來(lái)的基礎(chǔ)做起,讓開發(fā)者更關(guān)注更具體的業(yè)務(wù)問(wèn)題,而不是Web的請(qǐng)求和響應(yīng)的控制。

          框架很多,但套路基本類似,幫你隱藏很多關(guān)于 HTTP 協(xié)議細(xì)節(jié)內(nèi)容,專注功能開發(fā)。

          但對(duì)一個(gè)初學(xué)者來(lái)說(shuō),過(guò)早的接觸框架往往是事倍功半!同樣一個(gè)問(wèn)題,換一種框架你可能需要從頭開始研究。

          下面是針對(duì)初學(xué) Java 開發(fā) Web 過(guò)程一些個(gè)人見解和思路,高手可略過(guò)。

          1. 基本要求:Java 編程基礎(chǔ)

          有良好的 Java 語(yǔ)言編程基礎(chǔ),這是必須的,在討論 Web 開發(fā)技術(shù)時(shí)提了一個(gè) Java 編程基礎(chǔ)的問(wèn)題會(huì)被鄙視的。

          2. 環(huán)境準(zhǔn)備 (Eclipse + Tomcat)

          選擇一個(gè)你喜愛的Servlet容器,或者說(shuō)大一點(diǎn)就是應(yīng)用服務(wù)器,推薦 Tomcat 、Resin 或者 Jetty 這些輕量級(jí)的產(chǎn)品。這三個(gè)產(chǎn)品下載 zip 包解壓后就可以用了。如果你不熟悉 Tomcat 的話請(qǐng)不要使用 exe 版本的 Tomcat,那會(huì)徒增很多煩惱。

          把應(yīng)用服務(wù)器啟動(dòng)起來(lái)并能訪問(wèn)到其默認(rèn)的頁(yè)面為準(zhǔn)。

          關(guān)于開發(fā)工具:不推薦使用 MyEclipse 和 Eclipse 的 JEE 版本,徒增煩惱、運(yùn)行緩慢而且還讓你無(wú)法了解 Web 項(xiàng)目的結(jié)構(gòu)。普通的 Eclipse 或者你喜歡的開發(fā)工具就足夠了,能支持普通 Java 項(xiàng)目開發(fā)即可。

          為了方便,我做了一個(gè)最基本的Java 項(xiàng)目 —— ServletDemo.zip(評(píng)論區(qū)見鏈接) ,你可將它導(dǎo)入到 Eclipse 里就是一個(gè)完整的、最簡(jiǎn)單的 Web 項(xiàng)目。

          然后將下面 XML 內(nèi)容替換 Tomcat 下的 conf/server.xml 文件:

          <?xml version='1.0' encoding='utf-8'?>
          <Server port="8005" shutdown="SHUTDOWN">
            <Service name="Catalina">
              <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8"/>
              <Engine name="Catalina" defaultHost="localhost">
                <Host name="localhost">
          	<Context path="" docBase="D:\WORKDIR\ServletDemo\webapp" reloadable="true"/>
                </Host>
              </Engine>
            </Service>
          </Server>

          其中 D:\WORKDIR\ServletDemo 替換為你導(dǎo)入的項(xiàng)目路徑,再次啟動(dòng) Tomcat 后在瀏覽器打開 http://localhost:8080/hello 便可看到 Hello World 的輸出信息。

          3. 了解 Servlet 和 Filter

          好了,我已經(jīng)把環(huán)境搭起來(lái)了,接下來(lái)該干嘛呢?

          前面的步驟為的是搭建一個(gè)測(cè)試的環(huán)境,然后讓你了解一個(gè)最基本的 Java Web 項(xiàng)目的結(jié)構(gòu)。

          一個(gè)最基本的 Java Web 項(xiàng)目所需的 jar 包只需要一個(gè) servlet-api.jar ,這個(gè) jar 包中的類大部分都是接口,還有一些工具類,共有 2 個(gè)包,分別是 javax.servlet 和 javax.servlet.http。我把這個(gè)jar包放到了 webapp 目錄外的一個(gè)獨(dú)立 packages 文件夾里,這是因?yàn)樗械?Servlet 容器都帶有這個(gè)包,你無(wú)需再放到Web項(xiàng)目里,我們放到這里只不過(guò)是編譯的需要,運(yùn)行是不需要的。如果你硬是把 servlet-api.jar 放到 webapp/WEB-INF/lib 目錄下,那么 Tomcat 啟動(dòng)時(shí)還會(huì)報(bào)一個(gè)警告信息。

          Java Web 項(xiàng)目還需要一個(gè)非常重要的配置文件 web.xml ,在這個(gè)項(xiàng)目中已經(jīng)被我最小化了,只保留有用的信息:

          <?xml version="1.0" encoding="UTF-8"?>
          <!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>
          
          	<servlet>
          		<servlet-name>hello_world</servlet-name>
          		<servlet-class>demo.HelloServlet</servlet-class>
          		<load-on-startup>1</load-on-startup>
          	</servlet>
          
          	<servlet-mapping>
          		<servlet-name>hello_world</servlet-name>
          		<url-pattern>/hello</url-pattern>
          	</servlet-mapping>
          
          </web-app>


          每個(gè) servlet 都必須在 web.xml 中定義并進(jìn)行 URL 映射配置,早期 Java 開發(fā) Web 在沒(méi)有框架滿天飛的時(shí)候,這個(gè)文件會(huì)定義了大量的 servlet,或者有人為了省事干脆來(lái)一個(gè) /servlet/* 來(lái)通過(guò)類名直接調(diào)用 Servlet。

          Servlet 規(guī)范里還有另外一個(gè)非常重要而且非常有用的接口那就是 Filter 過(guò)濾器。

          下面是一個(gè)最簡(jiǎn)單的 Filter 類以及相應(yīng)的定義方法:

          package demo;
          
          import java.io.IOException;
          
          import javax.servlet.Filter;
          import javax.servlet.FilterChain;
          import javax.servlet.FilterConfig;
          import javax.servlet.ServletException;
          import javax.servlet.ServletRequest;
          import javax.servlet.ServletResponse;
          import javax.servlet.http.HttpServletRequest;
          
          public class HelloFilter implements Filter {
          
          	@Override
          	public void init(FilterConfig arg0) throws ServletException {
          		System.out.println("Filter 初始化");
          	}
          
          	@Override
          	public void doFilter(ServletRequest req, ServletResponse res,
          			FilterChain chain) throws IOException, ServletException {
          		HttpServletRequest request = (HttpServletRequest)req;
          		System.out.println("攔截 URI="+request.getRequestURI());
          		chain.doFilter(req, res);
          	}
          
          	@Override
          	public void destroy() {
          		System.out.println("Filter 結(jié)束");
          	}
          }

          在 web.xml 中的配置必須放在 Servlet 的前面:

          訪問(wèn) http://localhost:8080/hello 時(shí)看看 Tomcat 控制臺(tái)有何輸出信息。

          4. Servlet 和 HTTP 的對(duì)應(yīng)關(guān)系

          Servlet 是 J2EE 最重要的一部分,有了 Servlet 你就是 J2EE 了,J2EE 的其他方面的內(nèi)容擇需采用。而 Servlet 規(guī)范你需要掌握的就是 servlet 和 filter 這兩項(xiàng)技術(shù)。絕大多數(shù)框架不是基于 servlet 就是基于 filter,如果它要在 Servlet 容器上運(yùn)行,就永遠(yuǎn)也脫離不開這個(gè)模型。

          為什么 Servlet 規(guī)范會(huì)有兩個(gè)包,javax.servlet 和 javax.servlet.http ,早先設(shè)計(jì)該規(guī)范的人認(rèn)為 Servlet 是一種服務(wù)模型,不一定是依賴某種網(wǎng)絡(luò)協(xié)議之上,因此就抽象出了一個(gè) javax.servlet ,同時(shí)在提供一個(gè)基于 HTTP 協(xié)議上的接口擴(kuò)展。但是從實(shí)際運(yùn)行這么多年來(lái)看,似乎沒(méi)有發(fā)現(xiàn)有在其他協(xié)議上實(shí)現(xiàn)的 Servlet 技術(shù)。

          javax.servlet 和 javax.servlet.http 這兩個(gè)包總共加起來(lái)也不過(guò)是三十四個(gè)接口和類。你需要通過(guò) J2EE 的 JavaDoc 文檔 熟知每個(gè)類和接口的具體意思。特別是下面幾個(gè)接口必須熟知每個(gè)方法的意思和用途:

        1. HttpServlet
        2. ServetConfig
        3. ServletContext
        4. Filter
        5. FilterConfig
        6. FilterChain
        7. RequestDispatcher
        8. HttpServletRequest
        9. HttpServletResponse
        10. HttpSession
        11. 一些 Listenser 類
        12. 再次強(qiáng)調(diào) HttpServletRequest 和 HttpServletResponse 這兩個(gè)接口更應(yīng)該是爛熟于心。

          如果你從字面上無(wú)法理解某個(gè)方法的意思,你可以在前面那個(gè)項(xiàng)目的基礎(chǔ)上做實(shí)驗(yàn)看看其輸出,再不行你可以到討論區(qū)提問(wèn),這樣的提問(wèn)非常明確,很多人都可以幫到你。

          為什么我這么強(qiáng)調(diào) HttpServletRequest 和 HttpServletResponse 這兩個(gè)接口,因?yàn)?Web 開發(fā)是離不開 HTTP 協(xié)議的,而 Servlet 規(guī)范其實(shí)就是對(duì) HTTP 協(xié)議做面向?qū)ο蟮姆庋b,HTTP協(xié)議中的請(qǐng)求和響應(yīng)就是對(duì)應(yīng)了 HttpServletRequest 和 HttpServletResponse 這兩個(gè)接口。

          你可以通過(guò) HttpServletRequest 來(lái)獲取所有請(qǐng)求相關(guān)的信息,包括 URI、Cookie、Header、請(qǐng)求參數(shù)等等,別無(wú)它路。因此當(dāng)你使用某個(gè)框架時(shí),你想獲取HTTP請(qǐng)求的相關(guān)信息,只要拿到 HttpServletRequest 實(shí)例即可。

          而 HttpServletResponse接口是用來(lái)生產(chǎn) HTTP 回應(yīng),包含 Cookie、Header 以及回應(yīng)的內(nèi)容等等。

          5. 再談?wù)?Session

          HTTP 協(xié)議里是沒(méi)有關(guān)于 Session 會(huì)話的定義,Session 是各種編程語(yǔ)言根據(jù) HTTP 協(xié)議的無(wú)狀態(tài)這種特點(diǎn)而產(chǎn)生的。其實(shí)現(xiàn)無(wú)非就是服務(wù)器端的一個(gè)哈希表,哈希表的Key就是傳遞給瀏覽器的名為 jsessionid 的 Cookie 值。

          當(dāng)需要將某個(gè)值保存到 session 時(shí),容器會(huì)執(zhí)行如下幾步:

          a. 獲取 jsessionid 值,沒(méi)有的話就生成一個(gè),也就是 request.getSession() 這個(gè)方法b. 拿到的 HttpSession 對(duì)象實(shí)例就相當(dāng)于一個(gè)哈希表,你可以往哈希表里存放數(shù)據(jù)(setAttribute)c. 你也可以通過(guò) getAttribute 來(lái)獲取某個(gè)值

          而這個(gè)名為 jsessionid 的 Cookie 在瀏覽器關(guān)閉時(shí)會(huì)自動(dòng)刪除。把 Cookie 的 MaxAge 值設(shè)為 -1 就能達(dá)到瀏覽器關(guān)閉自動(dòng)刪除的效果。

          6. 關(guān)于 JSP

          首先我已經(jīng)不用 JSP 很多年了,現(xiàn)在一直是使用 Velocity 模板引擎。

          任何一個(gè) JSP 頁(yè)面在執(zhí)行的時(shí)候都會(huì)編譯成一個(gè) Servlet 類文件,如果是 Tomcat 的話,這些生成的 java 文件會(huì)放置在 {TOMCAT}/work 目錄下對(duì)應(yīng)項(xiàng)目的子目錄中,例如 Tomcat 生成的類文件如下:

          package org.apache.jsp;
          
          import javax.servlet.*;
          import javax.servlet.http.*;
          import javax.servlet.jsp.*;
          import java.util.*;
          
          public final class test_jsp extends org.apache.jasper.runtime.HttpJspBase
              implements org.apache.jasper.runtime.JspSourceDependent {
          
            private static final JspFactory _jspxFactory = JspFactory.getDefaultFactory();
          
            private static java.util.List<String> _jspx_dependants;
          
            private javax.el.ExpressionFactory _el_expressionfactory;
            private org.apache.tomcat.InstanceManager _jsp_instancemanager;
          
            public java.util.List<String> getDependants() {
              return _jspx_dependants;
            }
          
            public void _jspInit() {
              _el_expressionfactory = _jspxFactory.getJspApplicationContext(getServletConfig().getServletContext()).getExpressionFactory();
              _jsp_instancemanager = org.apache.jasper.runtime.InstanceManagerFactory.getInstanceManager(getServletConfig());
            }
          
            public void _jspDestroy() {
            }
          
            public void _jspService(final HttpServletRequest request, final HttpServletResponse response)
                  throws java.io.IOException, ServletException {
          
              final PageContext pageContext;
              HttpSession session = null;
              final ServletContext application;
              final ServletConfig config;
              JspWriter out = null;
              final Object page = this;
              JspWriter _jspx_out = null;
              PageContext _jspx_page_context = null;
          
          
              try {
                response.setContentType("text/html;charset=utf-8");
                pageContext = _jspxFactory.getPageContext(this, request, response,
                			null, true, 8192, true);
                _jspx_page_context = pageContext;
                application = pageContext.getServletContext();
                config = pageContext.getServletConfig();
                session = pageContext.getSession();
                out = pageContext.getOut();
                _jspx_out = out;
          
                out.write("\r\n");
                out.write("<html>\r\n");
                out.write("    <title>Test</title>\r\n");
                out.write("    <style>\r\n");
                out.write("    </style> \r\n");
                out.write("  <body>\r\n");
                out.write("<h1>Test Demo (oschina)</h1>\r\n");
                out.write("<table cellspacing=\"1\" cellpadding=\"5\">\r\n");
          
          Enumeration Names=request.getHeaderNames();
          while(Names.hasMoreElements())
          {String name=(String)Names.nextElement();
          String value=request.getHeader(name);
           
                out.write("\r\n");
                out.write(" <tr>\r\n");
                out.write(" <td>");
                out.print(name);
                out.write("</td>\r\n");
                out.write("  <td>");
                out.print(value);
                out.write("</td>\r\n");
                out.write(" \r\n");
                out.write(" </tr>\r\n");
                out.write(" ");
          
           }
            
                out.write("\r\n");
                out.write("</table>\r\n");
                out.write("  </body>\r\n");
                out.write("</html>");
              } catch (Throwable t) {
                if (!(t instanceof SkipPageException)){
                  out = _jspx_out;
                  if (out != null && out.getBufferSize() != 0)
                    try { out.clearBuffer(); } catch (java.io.IOException e) {}
                  if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);
                }
              } finally {
                _jspxFactory.releasePageContext(_jspx_page_context);
              }
            }
          }

          在 servlet 中有一個(gè)包 javax.servlet.jsp 是跟 JSP 相關(guān)的一些接口規(guī)范定義。JSP 比 Servlet 方便的地方在于可直接修改立即生效,不像 Servlet 修改后必須重啟容器才能生效。

          因此 JSP 適合用來(lái)做視圖,而 Servlet 則適合做控制層。

          7. 總結(jié)

          羅哩羅嗦一大堆,歸納一下就是下面幾點(diǎn):

          • 熟知 Servlet 規(guī)范之前,請(qǐng)不要學(xué)習(xí)任何框架
          • 使用最簡(jiǎn)單的工具,不要任何向?qū)Ш涂梢暬?/li>
          • 熟知 HTTP 協(xié)議

          等你真的掌握了 Servlet 規(guī)范再去看框架,便會(huì)覺得一些都小菜。總之一點(diǎn):不要被框架牽著鼻子走,框架是你的工具,它應(yīng)該聽你的!


          主站蜘蛛池模板: 国模大尺度视频一区二区| 丝袜无码一区二区三区| 乱码人妻一区二区三区| 一本一道波多野结衣AV一区| 精品国产福利一区二区| 国产精品一区视频| 国产女人乱人伦精品一区二区| 国产一区在线观看免费| 一区二区三区在线观看免费| 中文字幕在线观看一区| 无码人妻精品一区二区三区蜜桃| 无码夜色一区二区三区| 精品福利一区二区三区精品国产第一国产综合精品 | 一区二区三区在线播放视频| 日本一区二区三区高清| 国产精品一区二区久久精品涩爱| 国产精品一区二区三区久久 | 亚洲第一区香蕉_国产a| 亚洲第一区二区快射影院| 精品一区二区三区无码视频| 久久综合精品不卡一区二区| 天堂一区二区三区在线观看| 无码日韩人妻AV一区二区三区| 日本中文字幕一区二区有码在线| 一本一道波多野结衣AV一区| 精品视频一区二区三区| 亚洲国产一区二区三区在线观看| 国产精品小黄鸭一区二区三区 | 亚洲AV无码一区东京热久久 | 视频一区视频二区在线观看| 亚洲AV无码一区二区乱子伦 | 色综合视频一区中文字幕| 国产91精品一区二区麻豆亚洲| 国产短视频精品一区二区三区| 亚洲高清成人一区二区三区| 国产精品香蕉一区二区三区| 亚洲av午夜福利精品一区| 一区二区三区久久精品| 激情无码亚洲一区二区三区| 精品无码人妻一区二区三区| 亚洲高清成人一区二区三区|