<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    修改myEclipse自帶的tomcat發(fā)布端口

    首先到你的MyEclipse文件下去搜索server.xml 這個(gè)文件

    修改這個(gè)文件里面的一個(gè)參數(shù)

    <Connector port="8080" protocol="HTTP/1.1"

                   connectionTimeout="20000"

                   redirectPort="8443" />


    2.在Myeclipse中,在(工具欄吧叫做,就是有File Edit 的那一行),選window -> Preferences -> Myeclipse -> Servers -> Integrated Sandbox -> Myeclipse Tomcat 6修改相應(yīng)端口號(hào)

    posted @ 2012-05-29 21:52 youngturk 閱讀(5178) | 評(píng)論 (2)編輯 收藏

    request.getParameterMap()得到form頁面所有值

    example:
        
    <@global.dialogBegin title="轉(zhuǎn)棧申請(qǐng)審批"/>
    <form id="declare_form" method="post" action="${webroot}/delivery/receive!verify.do">    
        
    <input type="hidden" name="id" id="rowId">    
        
    <label>審核結(jié)果:</label><br/><input type="radio" id="yard_confirm_flag" name="yardConfirmFlag" value="Y">同意轉(zhuǎn)棧申請(qǐng)<input type="radio" id="yard_confirm_flag" name="yardConfirmFlag" value="N">拒絕轉(zhuǎn)棧申請(qǐng)<br/>
        
    <br/><label>審核意見:</label><br/><textarea name="yardConfirmComment" id="yard_confrim_comment" style="width:90%;height:60px;overflow:hidden;">同意轉(zhuǎn)棧申請(qǐng),等待海關(guān)審核</textarea><br/>
    </form>    
    <@global.dialogEnd button="審批"/>

      
    DeliveryMainIndex.java 

    private String yardConfirmComment ;

    public String getYardConfirmComment() {
      
    return yardConfirmComment;
     }


     
    public void setYardConfirmComment(String yardConfirmComment) {
      
    this.yardConfirmComment = yardConfirmComment;
     }


    DeliveryMainIndex obj = (DeliveryMainIndex)this.bindRequestToBean(DeliveryMainIndex.class);

        public Object bindRequestToBean(Class clazz){
            Object obj 
    = null ;
            
    try {
                obj 
    = clazz.newInstance();            
                BeanUtils.populate(obj, request.getParameterMap());//獲取ftl所有值,將其轉(zhuǎn)化成實(shí)體bean
            }
     catch (InstantiationException e) {
                
    // TODO Auto-generated catch block
                e.printStackTrace();
            }
     catch (IllegalAccessException e) {
                
    // TODO Auto-generated catch block
                e.printStackTrace();
            }
     catch (InvocationTargetException e) {
                
    // TODO Auto-generated catch block
                e.printStackTrace();
            }

            
    return obj ;
        }









    posted @ 2012-05-29 09:53 youngturk 閱讀(1829) | 評(píng)論 (2)編輯 收藏

    增加表列項(xiàng) alter table

    alter table test add ( test_column varchar2(20) )
    comment on column test_column is 'test'

    posted @ 2012-05-28 13:54 youngturk 閱讀(216) | 評(píng)論 (0)編輯 收藏

    heap,stack的區(qū)別

    example:
    Point p1 = new Point(1,2);
    Point p2 = new Point(3,4);

    p2 = p1 ; 此時(shí) 是p2指針的內(nèi)容指向了p1,p1和p2的內(nèi)容相等,但是p1的地址可能是1000,p2的地址是2000,p1,p2地址內(nèi)容值都指向同一內(nèi)容(1,2),此時(shí)(1,2)是heap,p2和p1的地址存向stack
    Point p3 = null;
    p3.moveto(1,2)此時(shí)報(bào)錯(cuò),p3沒對(duì)象;

    posted @ 2012-05-28 08:45 youngturk 閱讀(206) | 評(píng)論 (0)編輯 收藏

    視頻學(xué)習(xí)的第一個(gè)springMVC原創(chuàng)

         摘要: 首先我將所有需要的文件引入: Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->loging.jsp${error}  <body>    <form metho...  閱讀全文

    posted @ 2012-05-26 13:05 youngturk 閱讀(1270) | 評(píng)論 (1)編輯 收藏

    Method 類中 invoke方法的調(diào)用

    public void invokeActionHandler(ModelAndView mv , HttpServletRequest request) throws Exception{
            String className 
    = mv.getClassName();
            String methodName 
    = mv.getMethodName();
            
    //load class
            Class controllerClass = cache.loadClass(className);//== Class.forName(className);java反射機(jī)制,jvm加載lassName類
            Class parentControllerClass = cache.loadClass(baseControllerClass);//class org.bluechant.mvc.controller.Controller
            
    //load method參數(shù)1類,創(chuàng)建一個(gè)方法為setRequest參數(shù)為HttpServletRequest.class的方法與method = clazz.getDeclaredMethod(setRequest, HttpServletRequest.class);與HttpServletRequest的setRequest方法一致的方法.
            Method setRequest = cache.loadMethod(parentControllerClass, "setRequest"new Class[] { HttpServletRequest.class });    //HttpServletRequest.class,java的反射機(jī)制得到自己的類,能夠擁有自己的方法值,(Method setRequest獲取成員函數(shù))
            Method setModelAndView = cache.loadMethod(parentControllerClass, "setModelAndView"new Class[] { ModelAndView.class });//org.bluechant.mvc.controller.Controller-setModelAndView@6024418  public void org.bluechant.mvc.controller.Controller.setModelAndView(org.bluechant.mvc.controller.ModelAndView)
            Method targetMethod = cache.loadMethod(controllerClass, methodName, new Class[]{});
            
    //buiid controller instance and invoke target method以上setRequest,setModelAndView,targetMethod都放在cache(hashMap中)
            Object instance = controllerClass.newInstance();//加載className類
            setRequest.invoke(instance, new Object[] { request });//對(duì)帶有指定參數(shù)的指定對(duì)象調(diào)用由此 Method 對(duì)象表示的基礎(chǔ)方法    
            setModelAndView.invoke(instance, new Object[] { mv });//instance立即為原型指針
            targetMethod.invoke(instance, new Object[]{});    
            
    //調(diào)用instance類中targetMethod這個(gè)方法,Object[]{}這個(gè)作為參數(shù)..
            
    //invoke根據(jù)實(shí)體獲得方法,添加所要造的參數(shù),就是個(gè)找實(shí)例的方法克隆工廠,由Method獲得實(shí)例模型,由方法鍛造樣子,傳入?yún)?shù)得出想要結(jié)果
        }


    方法說明實(shí)例:


    }
    class ClassB{
     public ClassB(){
      System.out.println("this is ClassB");
     }

     public Object invokeMehton(Object owner,String methodName,Object[] args) throws Exception{
                      //根據(jù)methodName獲得owner里面的方法。args是對(duì)應(yīng)方案參數(shù)。
      Class wnerClass=owner.getClass();
      Class[] argsClass=new Class[args.length];
      for(int i=0,j=args.length;i<j;i++){
        argsClass[i] = args[i].getClass();
      }
      Method method = ownerClass.getMethod(methodName, argsClass); 
      return method.invoke(owner, args);
     }
    }

    輸出為
    this is ClassB
    300
    outabccc

    說明c調(diào)用Class方法成功。


    import java.lang.reflect.Method;

    public class ClassA {
            //ClassA里面有add、和StringAdd兩個(gè)不同方法。c是ClassB的Object
     ClassB c=new ClassB();
     public void add(Integer param1, Integer param2) {  
      
        System.out.println(param1 + param2);  
       
       }
     public void StringAdd(String abc){
      System.out.println("out"+abc);
     }
     public static void main(String[] args){
      ClassA a=new ClassA();
      try {
       a.c.invokeMehton(a, "add",new Object[] {new Integer(100),new Integer(200)});//反射調(diào)用方法add
       a.c.invokeMehton(a, "StringAdd",new Object[] {new String("abccc")});//反射調(diào)用方法StringAdd
      } catch (Exception e) {
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
      
      
      
     }


     



    posted @ 2012-05-24 18:54 youngturk 閱讀(605) | 評(píng)論 (0)編輯 收藏

    java連接數(shù)據(jù)庫(kù)(第一步)

    需要聯(lián)系的幾個(gè)文件:DaosupportController,extents Controller,BeanFactory,CoreDispatcherController,appcontext.xml.
    有web.xml中
    <servlet>
            <!-- servlet獲得控制文件Class的名字,類名 -->
      <servlet-name>smvcCoreDispatcher</servlet-name>
      <servlet-class>org.bluechant.mvc.core.CoreDispatcherController</servlet-class>
    .....
    </servlet>
    有CoreDispatcherController開始-->

    public void invokeActionHandler(ModelAndView mv , HttpServletRequest request) throws Exception{
            String className 
    = mv.getClassName();
            String methodName 
    = mv.getMethodName();
            
    //load class
            Class controllerClass = cache.loadClass(className);//== Class.forName(className);java反射機(jī)制,jvm加載lassName類
            Class parentControllerClass = cache.loadClass(baseControllerClass);//class org.bluechant.mvc.controller.Controller
            
    //load method參數(shù)1類,創(chuàng)建一個(gè)方法為setRequest參數(shù)為HttpServletRequest.class的方法與method = clazz.getDeclaredMethod(setRequest, HttpServletRequest.class);與HttpServletRequest的setRequest方法一致的方法.
            Method setRequest = cache.loadMethod(parentControllerClass, "setRequest"new Class[] { HttpServletRequest.class });    //HttpServletRequest.class,java的反射機(jī)制得到自己的類,能夠擁有自己的方法值,(Method setRequest獲取成員函數(shù))
            Method setModelAndView = cache.loadMethod(parentControllerClass, "setModelAndView"new Class[] { ModelAndView.class });//org.bluechant.mvc.controller.Controller-setModelAndView@6024418  public void org.bluechant.mvc.controller.Controller.setModelAndView(org.bluechant.mvc.controller.ModelAndView)
            Method targetMethod = cache.loadMethod(controllerClass, methodName, new Class[]{});
            
    //buiid controller instance and invoke target method以上setRequest,setModelAndView,targetMethod都放在cache(hashMap中)
            Object instance = controllerClass.newInstance();//加載className類;//此方法引入數(shù)據(jù)庫(kù)連接 
            //以上剛進(jìn)入頁面的時(shí)候instance調(diào)用三個(gè)類初始化,分別是繼承關(guān)系DaosupportController ,controller,和BeanFactory
            /*--->>>其中DaoSupportController類中protected ObjectDao dao = (ObjectDao)BeanFactory.getBean("objectDao");
            --->>>調(diào)用:getBean 方法public class BeanFactory {
                public static ApplicationContext context = new ClassPathXmlApplicationContext("appcontext.xml") ;//此方法引入數(shù)據(jù)庫(kù)連接                                        
                public static Object getBean(String beanId) {
                    return context.getBean(beanId);
                }
            }
    */

            setRequest.invoke(instance, 
    new Object[] { request });//對(duì)帶有指定參數(shù)的指定對(duì)象調(diào)用由此 Method 對(duì)象表示的基礎(chǔ)方法    
            setModelAndView.invoke(instance, new Object[] { mv });//instance立即為原型指針
    //        --->>>執(zhí)行指定的targetMethod方法實(shí)則為AccountController的login()登陸方法此時(shí)開始調(diào)用數(shù)據(jù)庫(kù)
            targetMethod.invoke(instance, new Object[]{});    
            
    //調(diào)用instance類中targetMethod這個(gè)方法,Object[]{}這個(gè)作為參數(shù)..
            
    //invoke根據(jù)實(shí)體獲得方法,添加所要造的參數(shù),就是個(gè)找實(shí)例的方法克隆工廠,由Method獲得實(shí)例模型,由方法鍛造樣子,傳入?yún)?shù)得出想要結(jié)果
        }

    }



    posted @ 2012-05-24 16:49 youngturk 閱讀(198) | 評(píng)論 (0)編輯 收藏

    java下Class.forName的作用是什么,為什么要使用它

    Class.forName(xxx.xx.xx) 返回的是一個(gè)類

    首先你要明白在java里面任何class都要裝載在虛擬機(jī)上才能運(yùn)行。這句話就是裝載類用的(和new 不一樣,要分清楚)。 

    至于什么時(shí)候用,你可以考慮一下這個(gè)問題,給你一個(gè)字符串變量,它代表一個(gè)類的包名和類名,你怎么實(shí)例化它?只有你提到的這個(gè)方法了,不過要再加一點(diǎn)。 
    A a = (A)Class.forName("pacage.A").newInstance(); 
    這和你 
    A a = new A(); 
    是一樣的效果。 

    關(guān)于補(bǔ)充的問題 
    答案是肯定的,jvm會(huì)執(zhí)行靜態(tài)代碼段,你要記住一個(gè)概念,靜態(tài)代碼是和class綁定的,class裝載成功就表示執(zhí)行了你的靜態(tài)代碼了。而且以后不會(huì)再走這段靜態(tài)代碼了。

    Class.forName(xxx.xx.xx) 返回的是一個(gè)類 
    Class.forName(xxx.xx.xx);的作用是要求JVM查找并加載指定的類,也就是說JVM會(huì)執(zhí)行該類的靜態(tài)代碼段

    動(dòng)態(tài)加載和創(chuàng)建Class 對(duì)象,比如想根據(jù)用戶輸入的字符串來創(chuàng)建對(duì)象 
    String str = 用戶輸入的字符串 
    Class t = Class.forName(str); 
    t.newInstance();

     在初始化一個(gè)類,生成一個(gè)實(shí)例的時(shí)候,newInstance()方法和new關(guān)鍵字除了一個(gè)是方法,一個(gè)是關(guān)鍵字外,最主要有什么區(qū)別?它們的區(qū)別在于創(chuàng)建對(duì)象的方式不一樣,前者是使用類加載機(jī)制,后者是創(chuàng)建一個(gè)新類。那么為什么會(huì)有兩種創(chuàng)建對(duì)象方式?這主要考慮到軟件的可伸縮、可擴(kuò)展和可重用等軟件設(shè)計(jì)思想。 

    Java中工廠模式經(jīng)常使用newInstance()方法來創(chuàng)建對(duì)象,因此從為什么要使用工廠模式上可以找到具體答案。 例如: 
    class c = Class.forName(“Example”); 
    factory = (ExampleInterface)c.newInstance(); 

    其中ExampleInterface是Example的接口,可以寫成如下形式: 
    String className = "Example"; 
    class c = Class.forName(className); 
    factory = (ExampleInterface)c.newInstance(); 

    進(jìn)一步可以寫成如下形式: 
    String className = readfromXMlConfig;//從xml 配置文件中獲得字符串 
    class c = Class.forName(className); 
    factory = (ExampleInterface)c.newInstance(); 

    上面代碼已經(jīng)不存在Example的類名稱,它的優(yōu)點(diǎn)是,無論Example類怎么變化,上述代碼不變,甚至可以更換Example的兄弟類Example2 , Example3 , Example4……,只要他們繼承ExampleInterface就可以。 

    從JVM的角度看,我們使用關(guān)鍵字new創(chuàng)建一個(gè)類的時(shí)候,這個(gè)類可以沒有被加載。但是使用newInstance()方法的時(shí)候,就必須保證:1、這個(gè)類已經(jīng)加載;2、這個(gè)類已經(jīng)連接了。而完成上面兩個(gè)步驟的正是Class的靜態(tài)方法forName()所完成的,這個(gè)靜態(tài)方法調(diào)用了啟動(dòng)類加載器,即加載 java API的那個(gè)加載器。 

    現(xiàn)在可以看出,newInstance()實(shí)際上是把new這個(gè)方式分解為兩步,即首先調(diào)用Class加載方法加載某個(gè)類,然后實(shí)例化。 這樣分步的好處是顯而易見的。我們可以在調(diào)用class的靜態(tài)加載方法forName時(shí)獲得更好的靈活性,提供給了一種降耦的手段。 

    最后用最簡(jiǎn)單的描述來區(qū)分new關(guān)鍵字和newInstance()方法的區(qū)別: 
    newInstance: 弱類型。低效率。只能調(diào)用無參構(gòu)造。 
    new: 強(qiáng)類型。相對(duì)高效。能調(diào)用任何public構(gòu)造。

    posted @ 2012-05-24 14:32 youngturk 閱讀(207) | 評(píng)論 (0)編輯 收藏

    web.xml中 filter解析

    AdminFilter.java:
    package org.bluechant.mvc.filter;

    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;
    import javax.servlet.http.HttpServletResponse;
    import javax.servlet.http.HttpSession;

    import org.bluechant.mvc.core.GlobalSources;

    /**
     * 
    @author CHAOS
     * @date 2012-02-28 12:49
     * filter for check wheather user already login in ,
     * if not , send redirect to the login page 
     * if already login , forward user's request to the target request URL
     
    */

    public class AdminFilter implements Filter 
        
        
    private String loginPage ;
        
        
    private String loginAction ;
        
        
    private String userLoginTag ;
        
    //FilterConfig可用于訪問Filter的配置信息
        private FilterConfig config;

        
    //執(zhí)行過濾的核心方法
        public void doFilter(ServletRequest req, ServletResponse res,
                FilterChain chain) 
    throws IOException, ServletException {
            
            HttpServletRequest request 
    = (HttpServletRequest) req;
            HttpServletResponse  response 
    = (HttpServletResponse )res;
            HttpSession session 
    = request.getSession(true);

            
    //獲取客戶請(qǐng)求的頁面
            String urlPath = request.getServletPath();
            
    //如果session范圍的user為null,即表明沒有登錄
            
    //且用戶請(qǐng)求的既不是登錄頁面,也不是處理登錄的頁面if( session.getAttribute("user") == null

            
    boolean flag = needNotFilter(urlPath);
            
    //不需要進(jìn)行攔截的頁面
            if(!flag){
                Object obj 
    = session.getAttribute(userLoginTag);
                System.out.println(
    "the session userLoginTag value is :"+obj);
                
    if(obj!=null){
                    flag 
    = true ;
                }

            }

            
    if(flag){
                chain.doFilter(req, res);
            }
    else{
                
    //攔截不通過的時(shí)候跳轉(zhuǎn)到的目標(biāo)//forward到登錄頁面
                response.sendRedirect(request.getContextPath()+loginPage);
            }

        }

        
    //只有在”/login.html“ || “/account!login.do” 情況下才進(jìn)行攔截通過,否則攔截不通過跳到登陸頁面
        private boolean needNotFilter(String urlPath){
            
    if(urlPath.endsWith(loginPage) || urlPath.endsWith(loginAction)){
                
    return true ;
            }

            
    return false ;
        }


        
    /**
         * init params
         
    */

        
    public void init(FilterConfig config) throws ServletException {
            loginPage 
    = config.getInitParameter("loginPage");
            loginAction 
    = config.getInitParameter("loginAction");
            userLoginTag 
    = config.getInitParameter("userLoginTag");
            System.out.println(
    "the loginPage value is :"+loginPage);
            System.out.println(
    "the loginAction value is :"+loginAction);
            System.out.println(
    "the userLoginTag value is :"+userLoginTag);
            
    this.config = config;
            
    //以前頁面登陸的時(shí)候session進(jìn)行設(shè)置HttpSession session = request.getSession(true);
            
    //session.setAttribute(GlobalSources.user_login_tag, user);
            GlobalSources.user_login_tag = userLoginTag ;//session放到GlobalSources,bean里,
    用GlobalSources.user_login_tag獲得

        }


        
    public void destroy(){
            
            
    this.config = null;
        }


    }


    web.xml中對(duì)應(yīng)filter文件:
     <filter>
          <filter-name>adminFilter</filter-name>
          <filter-class>org.bluechant.mvc.filter.AdminFilter</filter-class>
              <init-param>
                   <param-name>loginAction</param-name>
                   <param-value>/account!login.do</param-value>
              </init-param>
              <init-param>
                   <param-name>loginPage</param-name>
                   <param-value>/login.html</param-value>
              </init-param>
              <init-param>
                   <param-name>userLoginTag</param-name>
                   <param-value>account_login_check</param-value>
              </init-param>  
     </filter>
     
     <filter>
              <filter-name>userSourceFilter</filter-name>
              <filter-class>org.bluechant.mvc.filter.AccountRoleFilter</filter-class>
     </filter>
     
     <filter-mapping>
              <filter-name>adminFilter</filter-name>
              <url-pattern>*.do</url-pattern><!-- 表明凡是訪問跳轉(zhuǎn)*.do形式的跳轉(zhuǎn),都要運(yùn)行名字為adminFilter的過濾器 -->
     </filter-mapping>
     
     <filter-mapping>
              <filter-name>userSourceFilter</filter-name>
              <url-pattern>*.do</url-pattern>
     </filter-mapping>

    posted @ 2012-05-24 10:40 youngturk 閱讀(897) | 評(píng)論 (0)編輯 收藏

    web.xml filter聲明過濾器

    過濾器可截取和修改進(jìn)入一個(gè)servlet或JSP頁面的請(qǐng)求或從一個(gè)servlet或JSP頁面發(fā)出的相應(yīng)。在執(zhí)行一個(gè) servlet或JSP頁面之前,必須執(zhí)行第一個(gè)相關(guān)的過濾器的doFilter方法。在該過濾器對(duì)其FilterChain對(duì)象調(diào)用doFilter 時(shí),執(zhí)行鏈中的下一個(gè)過濾器。如果沒有其他過濾器,servlet或JSP頁面被執(zhí)行。過濾器具有對(duì)到來的ServletRequest對(duì)象的全部訪問權(quán),因此,它們可以查看客戶機(jī)名、查找到來的cookie等。為了訪問servlet或JSP頁面的輸出,過濾器可將響應(yīng)對(duì)象包裹在一個(gè)替身對(duì)象(stand-in object)中,比方說把輸出累加到一個(gè)緩沖區(qū)。在調(diào)用FilterChain對(duì)象的doFilter方法之后,過濾器可檢查緩沖區(qū),如有必要,就對(duì)它進(jìn)行修改,然后傳送到客戶機(jī)。
        <filter>
            
    <filter-name>adminFilter</filter-name>
            
    <filter-class>org.bluechant.mvc.filter.AdminFilter</filter-class><!--服務(wù)器部署的時(shí)候,adminFilter開始加載初始化-->
            
    <init-param>
                
    <param-name>loginAction</param-name>
                
    <param-value>/account!login.do</param-value>
            
    </init-param>
            
    <init-param>
                
    <param-name>loginPage</param-name>
                
    <param-value>/login.html</param-value>
            
    </init-param>
            
    <init-param>
                
    <param-name>userLoginTag</param-name>
                
    <param-value>account_login_check</param-value>
            
    </init-param>        
        
    </filter>
        
        
    <filter>
            
    <filter-name>userSourceFilter</filter-name>
            
    <filter-class>org.bluechant.mvc.filter.AccountRoleFilter</filter-class>
        
    </filter>
        
        
    <filter-mapping>
            
    <filter-name>adminFilter</filter-name>
            
    <url-pattern>*.do</url-pattern><!-- 表明凡是訪問跳轉(zhuǎn)*.do形式的跳轉(zhuǎn),都要運(yùn)行名字為adminFilter的過濾器 -->
        
    </filter-mapping>
        
        
    <filter-mapping>
            
    <filter-name>userSourceFilter</filter-name>
            
    <url-pattern>*.do</url-pattern>
        
    </filter-mapping>
        <!--接著順序加載servlet被初始化-->

    posted @ 2012-05-23 22:31 youngturk 閱讀(647) | 評(píng)論 (1)編輯 收藏

    僅列出標(biāo)題
    共33頁: First 上一頁 13 14 15 16 17 18 19 20 21 下一頁 Last 
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導(dǎo)航

    統(tǒng)計(jì)

    公告

    this year :
    1 jQuery
    2 freemarker
    3 框架結(jié)構(gòu)
    4 口語英語

    常用鏈接

    留言簿(6)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    相冊(cè)

    EJB學(xué)習(xí)

    Flex學(xué)習(xí)

    learn English

    oracle

    spring MVC web service

    SQL

    Struts

    生活保健

    解析文件

    搜索

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 国产亚洲精品成人久久网站| 亚洲中文字幕久久精品无码A | 成全高清视频免费观看| 亚洲欧洲日产国码二区首页 | 成年女人毛片免费播放人| 亚洲色图在线播放| 99在线视频免费| 亚洲国产成AV人天堂无码| 在线永久看片免费的视频| 激情综合亚洲色婷婷五月APP| 久草视频免费在线观看| 国产精品亚洲综合久久| 高清在线亚洲精品国产二区| eeuss草民免费| 久久精品国产亚洲香蕉| 国产在线观看片a免费观看| 亚洲国产美女精品久久久| 亚洲成av人片在线观看天堂无码 | 免费国产污网站在线观看不要卡| 国产免费av片在线无码免费看| 猫咪免费人成网站在线观看入口| 在线精品亚洲一区二区三区| 久久99精品免费视频| ASS亚洲熟妇毛茸茸PICS| 日本特黄特色aa大片免费| 久久免费99精品国产自在现线| 亚洲国产精品特色大片观看完整版| 99精品在线免费观看| 中文日韩亚洲欧美制服| 亚洲精品国产精品乱码不卞| 久久青草91免费观看| 亚洲日本VA午夜在线电影| 亚洲精品无码成人片久久| 国产福利视精品永久免费| 国产亚洲男人的天堂在线观看| 亚洲色大成网站www永久一区| 日韩国产免费一区二区三区| 免费的黄色的网站| 亚洲综合图片小说区热久久| 国产禁女女网站免费看| 69视频在线观看高清免费|