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

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

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

    posts - 41, comments - 15, trackbacks - 0, articles - 1
      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

    2014年5月21日

    有時(shí)候在客戶端使用svg畫(huà)圖,而在服務(wù)器端需要同樣的圖片,在服務(wù)器端重新畫(huà)一遍是非常費(fèi)事的。這時(shí)候我們就可以利用已有的svg直接通過(guò)下面的類(lèi)轉(zhuǎn)換成png格式。

    使用這個(gè)方法需要引用batic相關(guān)的包,maven pom文件如下:

    <!-- svg 生成png格式圖片  -->
    <dependency><groupId>batik</groupId><artifactId>batik-svggen</artifactId><version>1.6</version></dependency>        
    <dependency><groupId>batik</groupId><artifactId>batik-awt-util</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-bridge</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-css</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-dom</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-gvt</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-parser</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-script</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-svg-dom</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-transcoder</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-util</artifactId><version>1.6</version></dependency>
    <dependency><groupId>batik</groupId><artifactId>batik-xml</artifactId><version>1.6</version></dependency>
    <!-- 此處不能使用2.9.1版本,使用2.9.1生成png會(huì)失敗 -->
    <dependency><groupId>xerces</groupId><artifactId>xercesImpl</artifactId><version>2.5.0</version></dependency>
    <dependency><groupId>xml-apis</groupId><artifactId>xmlParserAPIs</artifactId><version>2.0.2</version></dependency>
    <dependency><groupId>org.axsl.org.w3c.dom.svg</groupId><artifactId>svg-dom-java</artifactId><version>1.1</version></dependency>
    <dependency><groupId>xml-apis</groupId>    <artifactId>xml-apis</artifactId><version>2.0.0</version></dependency>
    <dependency><groupId>org.w3c.css</groupId> <artifactId>sac</artifactId>    <version>1.3</version></dependency>
    <!-- svg 生成png格式圖片結(jié)束  -->
    package com.yhb.web.util;
    import java.io.ByteArrayInputStream;
    import java.io.File;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.OutputStream;
    import java.io.UnsupportedEncodingException;
    import java.net.URL;
    import org.apache.batik.transcoder.TranscoderException;
    import org.apache.batik.transcoder.TranscoderInput;
    import org.apache.batik.transcoder.TranscoderOutput;
    import org.apache.batik.transcoder.image.PNGTranscoder;
    public final class FileUtil {
    /** 
         *@Description: 將svg字符串轉(zhuǎn)換為png 
         *@Author: 
         *@param svgCode svg代碼 
         *@param pngFilePath  保存的路徑 
         *@throws IOException io異常 
         *@throws TranscoderException svg代碼異常 
        */  
    public static void convertToPng(String svgCode,String pngFilePath) throws IOException,TranscoderException{  
     
            File file = new File (pngFilePath);  
      
            FileOutputStream outputStream = null;  
            try {  
                file.createNewFile ();  
                outputStream = new FileOutputStream (file);  
                convertToPng (svgCode, outputStream);  
            } finally {  
                if (outputStream != null) {  
                    try {  
                        outputStream.close ();  
                    } catch (IOException e) {  
                        e.printStackTrace ();  
                    }  
                }  
            }  
        }  
    /** 
         *@Description: 將svgCode轉(zhuǎn)換成png文件,直接輸出到流中 
         *@param svgCode svg代碼 
         *@param outputStream 輸出流 
         *@throws TranscoderException 異常 
         *@throws IOException io異常 
         */  
        public static void convertToPng(String svgCode,OutputStream outputStream) throws TranscoderException,IOException{  
            try {  
            byte[] bytes = svgCode.getBytes ("UTF-8");  
                PNGTranscoder t = new PNGTranscoder ();  
                TranscoderInput input = new TranscoderInput (new ByteArrayInputStream (bytes));  
                TranscoderOutput output = new TranscoderOutput (outputStream);  
                t.transcode (input, output);  
                outputStream.flush ();  
            } finally {  
                if (outputStream != null) {  
                    try {  
                        outputStream.close ();  
                    } catch (IOException e) {  
                        e.printStackTrace ();  
                    }  
                }  
            }  
        }  
    }

    posted @ 2015-10-19 15:17 yuhaibo736 閱讀(319) | 評(píng)論 (0)編輯 收藏

    方法1: 設(shè)定環(huán)境變量
    set NLS_SORT=SCHINESE_RADICAL_M ;export NLS_SORT (sh)
    or setenv NLS_SORT SCHINESE_RADICAL_M (csh)
    or regedit 
    HKLC/SOFTWARE/ORACLE/home0/NLS_SORT        (win)

    方法2: 在session中修改
    alter session set NLS_SORT='SCHINESE_RADICAL_M'

    方法3: 直接使用NLSSORT函數(shù) (推薦)
    select name,id from t
    order by NLSSORT(name,'NLS_SORT = SCHINESE_STROKE_M')

    設(shè)置NLS_SORT值:

    SCHINESE_RADICAL_M 按照部首(第一順序)、筆劃(第二順序)排序 

    SCHINESE_STROKE_M 按照筆劃(第一順序)、部首(第二順序)排序 

    SCHINESE_PINYIN_M 按照拼音排序

    posted @ 2014-08-29 14:13 yuhaibo736 閱讀(1290) | 評(píng)論 (0)編輯 收藏

        在IBATIS中,框架內(nèi)置了對(duì)OSCache的支持,如果我們想使用EHCache,則需要通過(guò)我們手工實(shí)現(xiàn)來(lái)完成二級(jí)緩存的功能機(jī)制。

        在mybatis中,開(kāi)發(fā)組織只提供了一些默認(rèn)的二級(jí)緩存實(shí)現(xiàn)的機(jī)制,并沒(méi)有直接內(nèi)置的支持OSCache和EHCache等二級(jí)緩存機(jī)制,而是作為一個(gè)集成jar包來(lái)提供二級(jí)緩存的實(shí)現(xiàn),在官方網(wǎng)站上我們可以找到mybatis-ehcache-1.0.1-bundle.zip,mybatis-oscache-1.0.1-bundle.zip等ehcache和oscache提供二級(jí)緩存的獨(dú)立工具包. 這里我就拿oscache在mybatis中的使用來(lái)舉例說(shuō)明:

           1.   將mybatis-oscache-1.0.1-bundle.zip中涉及到的jar包放入到classpath路徑下 
                 maven下可以這樣配置
                   <dependencies>  
                        
    ... 

                        <dependency> 

                            <groupId>org.mybatis.caches</groupId> 

                            <artifactId>mybatis-oscache</artifactId>      
                             <version>1.0.2-SNAPSHOT</version> 

                        </dependency>             

                        <dependency>
                            <groupId>javax.jms</groupId>
                            <artifactId>jms</artifactId>
                            <version>1.1</version>
                        </dependency>

                        <dependency>
                             <groupId>opensymphony</groupId>
                             <artifactId>oscache</artifactId>
                             <version>2.4</version>
                             <exclusions>       
                                   <exclusion>
                                       <groupId>com.sun.jdmk</groupId>
                                       <artifactId>jmxtools</artifactId>
                                   </exclusion>
                               <exclusion>
                               <groupId>com.sun.jmx</groupId>
                               <artifactId>jmxri</artifactId>
                           </exclusion>
                         </exclusions>
                    </dependency>

                        ... 

                    </dependencies>

           2.   在mapper文件中的配置如下:

                 <mapper namespace="org.test.AuthMapper" >         

                     <cache  type="org.mybatis.caches.oscache.OSCache"/>

                 </mapper>
                注意下面兩點(diǎn)
                 (a)在
    <select id="getAuth" parameterType="Map" resultType="Auth"  useCache="false">中使用useCache="false"或useCache="true"來(lái)決定是否使用二級(jí)緩存。    
                 (b)在增刪改中<insert id="insertAuth" parameterType="Auth"  flushCache="true">使用flushCache="true"或flushCache="flase"來(lái)決定對(duì)這些進(jìn)行操作后清空該xml文件中所有查詢語(yǔ)句的二級(jí)緩存。 

           3.  在src目錄下創(chuàng)建一個(gè)oscache.properties的屬性文件,在里面指定緩存的各種屬性的設(shè)置:
                 cache.memory=true             
                 cache.path=c:\\myapp\\cache
                 cache.persistence.class=com.opensymphony.oscache.plugins.diskpersistence.DiskPersistenceListener
                 cache.persistence.overflow.only=true
                 cache.capacity=100000

                

    posted @ 2014-08-11 18:22 yuhaibo736 閱讀(2736) | 評(píng)論 (0)編輯 收藏

    import java.awt.Color;
    import java.io.FileOutputStream;

    import com.itextpdf.text.BaseColor;
    import com.itextpdf.text.Document;
    import com.itextpdf.text.Element;
    import com.itextpdf.text.Font;
    import com.itextpdf.text.PageSize;
    import com.itextpdf.text.Phrase;
    import com.itextpdf.text.Rectangle;
    import com.itextpdf.text.pdf.BaseFont;
    import com.itextpdf.text.pdf.PdfPCell;
    import com.itextpdf.text.pdf.PdfPTable;
    import com.itextpdf.text.pdf.PdfWriter;

    public class CellEvents {


     /**
      * @param args
      */
     public static void main(String[] args) {
      Object[] objArr = new Object[]{100,20,300};
      
      Document document = new Document(PageSize.A4.rotate(),50,50,50,50);
      try{
       //bfSongti = BaseFont.createFont("/simsun.ttc,1", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
       Font songtiSFivefont = new Font(BaseFont.createFont("/simsun.ttc,1", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED), 9f);//宋體小五號(hào)字
             //設(shè)置存放位置
             PdfWriter.getInstance(document, new FileOutputStream("D:/test.pdf"));
             document.open();
     
             PdfPTable table = new PdfPTable(5);
       table.setSpacingBefore(10f);
       table.getDefaultCell().setPadding(5);
       //HowbuyBorderPdfPTableEvent event = new HowbuyBorderPdfPTableEvent();
       //table.setTableEvent(event);
       //table.getDefaultCell().setBorder(Rectangle.NO_BORDER);
       table.getDefaultCell().setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.getDefaultCell().setHorizontalAlignment(Element.ALIGN_CENTER);
       PdfPCell cellTitle = new PdfPCell(new Phrase("總資產(chǎn)\n(萬(wàn)元)",songtiSFivefont));
       cellTitle.setBorderWidth(2f);
       cellTitle.setBackgroundColor(new BaseColor(new Color(153, 51, 0)));
       cellTitle.setBorderColor(new BaseColor(new Color(153, 51, 0)));
       cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
       cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
       cellTitle.setMinimumHeight(25);
       table.addCell(cellTitle);
     
       cellTitle = new PdfPCell(new Phrase(""));
       cellTitle.setBorder(Rectangle.NO_BORDER);
       cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
       cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cellTitle);
       
       cellTitle = new PdfPCell(new Phrase("當(dāng)前收益\n(萬(wàn)元)",songtiSFivefont));
       cellTitle.setBorderWidth(2f);
       cellTitle.setBackgroundColor(new BaseColor(new Color(153, 51, 0)));
       cellTitle.setBorderColor(new BaseColor(new Color(153, 51, 0)));
       cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
       cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cellTitle);
     
       cellTitle = new PdfPCell(new Phrase("",songtiSFivefont));
       cellTitle.setBorder(Rectangle.NO_BORDER);
       cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
       cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cellTitle);
       
       
       cellTitle = new PdfPCell(new Phrase("累計(jì)收益\n(萬(wàn)元)",songtiSFivefont));
       cellTitle.setBorderWidth(2f);
       cellTitle.setBackgroundColor(new BaseColor(new Color(153, 51, 0)));
       cellTitle.setBorderColor(new BaseColor(new Color(153, 51, 0)));
       cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
       cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cellTitle);
       
       float[] widths2 = { 24.5f, 12.25f,24.5f,12.25f,24.5f};

       table.setWidths(widths2);
       
       table.setHorizontalAlignment(Element.ALIGN_LEFT);//
       table.setWidthPercentage(70);
       double zzc = objArr[0]==null ? 0:Double.parseDouble(objArr[0].toString());
       double dqsy = objArr[1]==null ? 0:Double.parseDouble(objArr[1].toString());
       double ljsy = objArr[2]==null ? 0:Double.parseDouble(objArr[2].toString());
       PdfPCell cell1 = new PdfPCell(new Phrase(String.valueOf(zzc),songtiSFivefont));
       cell1.setBorderWidth(2f);
       cell1.setBorderColor(new BaseColor(new Color(153, 51, 0)));
       cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
       cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
       cell1.setMinimumHeight(20);
       table.addCell(cell1);
       
       cell1 = new PdfPCell(new Phrase("",songtiSFivefont));
       cell1.setBorder(Rectangle.NO_BORDER);
       cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
       cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cell1);
       
       cell1 = new PdfPCell(new Phrase(String.valueOf(dqsy),songtiSFivefont));
       cell1.setBorderWidth(2f);
       cell1.setBorderColor(new BaseColor(new Color(153, 51, 0)));
       cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
       cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cell1);
       
       cell1 = new PdfPCell(new Phrase("",songtiSFivefont));
       cell1.setBorder(Rectangle.NO_BORDER);
       cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
       cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cell1);
       
       cell1 = new PdfPCell(new Phrase(String.valueOf(ljsy),songtiSFivefont));
       cell1.setBorderWidth(2f);
       cell1.setBorderColor(new BaseColor(new Color(153, 51, 0)));
       cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
       cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
       table.addCell(cell1);
       document.add(table);
      }catch(Exception ex){
       ex.printStackTrace();
      }
            document.close();

     }

    }

    posted @ 2014-06-24 16:27 yuhaibo736 閱讀(1468) | 評(píng)論 (0)編輯 收藏

    相信很多人都聽(tīng)過(guò)nginx,這個(gè)小巧的東西慢慢地在吞食apache和IIS的份額。那究竟它有什么作用呢?可能很多人未必了解。

    說(shuō)到反向代理,可能很多人都聽(tīng)說(shuō),但具體什么是反向代理,很多人估計(jì)就不清楚了。摘一段百度百科上的描述:

    Html代碼 復(fù)制代碼 收藏代碼
    1. 反向代理(Reverse Proxy)方式是指以代理服務(wù)器來(lái)接受internet上的連接請(qǐng)求,然后將請(qǐng)求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器,并將從服務(wù)器上得到的結(jié)果返回給internet上請(qǐng)求連接的客戶端,此時(shí)代理服務(wù)器對(duì)外就表現(xiàn)為一個(gè)服務(wù)器。 

    這里講得很直白。反向代理方式實(shí)際上就是一臺(tái)負(fù)責(zé)轉(zhuǎn)發(fā)的代理服務(wù)器,貌似充當(dāng)了真正服務(wù)器的功能,但實(shí)際上并不是,代理服務(wù)器只是充當(dāng)了轉(zhuǎn)發(fā)的作用,并且從真正的服務(wù)器那里取得返回的數(shù)據(jù)。這樣說(shuō),其實(shí)nginx完成的就是這樣的工作。我們讓nginx監(jiān)聽(tīng)一個(gè)端口,譬如80端口,但實(shí)際上我們轉(zhuǎn)發(fā)給在8080端口的tomcat,由它來(lái)處理真正的請(qǐng)求,當(dāng)請(qǐng)求完成后,tomcat返回,但數(shù)據(jù)此時(shí)沒(méi)直接返回,而是直接給nginx,由nginx進(jìn)行返回,這里,我們會(huì)以為是nginx進(jìn)行了處理,但實(shí)際上進(jìn)行處理的是tomcat。

    說(shuō)到上面的方式,也許很多人又會(huì)想起來(lái),這樣可以把靜態(tài)文件交由nginx來(lái)進(jìn)行處理。對(duì),很多用到nginx的地方都是作為靜態(tài)伺服器,這樣可以方便緩存那些靜態(tài)文件,比如CSS,JS,html,htm等文件。

    閑話就不多說(shuō)了,我們直接來(lái)看看nginx怎么使用。

    1)要用到的軟件當(dāng)然要下載啦。到nginx官網(wǎng)下一個(gè)。http://nginx.org/en/download.html可以到這里去下。我現(xiàn)在用的版本是1.1.7,但基本上以后的版本都兼容,而且我們用到的并不涉及到太底層的,應(yīng)該不會(huì)有什么變化。

    這里,由于我的是windows,當(dāng)然下windows版啦。下完后首先要啟動(dòng)吧。進(jìn)入到nginx文件夾,直接start nginx就OK了。

    比如我下載后放在D:\software\developerTools\server\nginx-1.1.7,直接cmd后cd D:\software\developerTools\server\nginx-1.1.7,有些不習(xí)慣命令行的可能會(huì)奇怪,它沒(méi)有進(jìn)行到那個(gè)文件夾。windows并不會(huì)在分區(qū)間跳轉(zhuǎn),除非你自己指定了。所以我們要直接d:如下:

    然后,我們直接start nginx,這里也許你會(huì)看到一個(gè)窗口一閃而過(guò),根據(jù)我們使用tomcat的經(jīng)驗(yàn),如果一閃而過(guò),證明有錯(cuò)誤了,是吧?但實(shí)際上不是。

    此時(shí)我們打開(kāi)任務(wù)管理器,可以看到兩個(gè)nginx.exe在那里好好的。這說(shuō)明我們已經(jīng)啟動(dòng)了,至于為什么兩個(gè),我們這里不深究。

    現(xiàn)在,我們已經(jīng)啟動(dòng)了nginx,這時(shí)就可以啟動(dòng)tomcat,想著直接訪問(wèn)http://localhost就可以直接訪問(wèn)tomcat了。

    先不急,我們來(lái)看看啟動(dòng)后的nginx是怎樣的。直接訪問(wèn)http://localhost可以看到:

        我們可以看到nginx啟動(dòng)成功,現(xiàn)在訪問(wèn)是直接進(jìn)到nginx的目錄里面了。

    那么這些實(shí)際上是在哪里配置的。這就涉及到nginx的一個(gè)重要配置文件nginx.conf了。

    2)我們可以看到nginx文件夾內(nèi)有一個(gè)conf文件夾,其中有好幾個(gè)文件,其他先不管,我們打開(kāi)nginx.conf,可以看到一段:

    這段代碼在server里面,相當(dāng)于一個(gè)代理服務(wù)器,當(dāng)然可以配置多個(gè)。

    下面我們仔細(xì)來(lái)分析一下:

    listen:表示當(dāng)前的代理服務(wù)器監(jiān)聽(tīng)的端口,默認(rèn)的是監(jiān)聽(tīng)80端口。注意,如果我們配置了多個(gè)server,這個(gè)listen要配置不一樣,不然就不能確定轉(zhuǎn)到哪里去了。

    server_name:表示監(jiān)聽(tīng)到之后需要轉(zhuǎn)到哪里去,這時(shí)我們直接轉(zhuǎn)到本地,這時(shí)是直接到nginx文件夾內(nèi)。

    location:表示匹配的路徑,這時(shí)配置了/表示所有請(qǐng)求都被匹配到這里

    root:里面配置了root這時(shí)表示當(dāng)匹配這個(gè)請(qǐng)求的路徑時(shí),將會(huì)在這個(gè)文件夾內(nèi)尋找相應(yīng)的文件,這里對(duì)我們之后的靜態(tài)文件伺服很有用。

    index:當(dāng)沒(méi)有指定主頁(yè)時(shí),默認(rèn)會(huì)選擇這個(gè)指定的文件,它可以有多個(gè),并按順序來(lái)加載,如果第一個(gè)不存在,則找第二個(gè),依此類(lèi)推。

    下面的error_page是代表錯(cuò)誤的頁(yè)面,這里我們暫時(shí)不用,先不管它。

    那我們知道了具體的配置了,怎么讓它訪問(wèn)localhost時(shí)轉(zhuǎn)到tomcat時(shí)。實(shí)際上就修改兩個(gè)地方:

    Java代碼 復(fù)制代碼 收藏代碼
    1. server_name localhost:8080
    2.  
    3. location / { 
    4.     proxy_pass http://localhost:8080 

    我們就修改了上面兩個(gè)地方,我的tomcat在8080端口,可以根據(jù)自己的需要修改。這里有一個(gè)新元素proxy_pass,它表示代理路徑,相當(dāng)于轉(zhuǎn)發(fā),而不像之前說(shuō)的root必須指定一個(gè)文件夾。

    此時(shí)我們修改了文件,是不是就意思著必須先關(guān)了nginx再重新啟動(dòng)了,其實(shí)不必,nginx可以重新加載文件的。

    我們直接運(yùn)行:

    Html代碼 復(fù)制代碼 收藏代碼
    1. nginx -s reload 

    高興得太早了,我們發(fā)現(xiàn)有一個(gè)錯(cuò)誤:

    什么來(lái)的,45行發(fā)現(xiàn)錯(cuò)誤,不希望在那一行找到},于是我們仔細(xì)找,發(fā)現(xiàn)我們加入的proxy_pass很奇怪,沒(méi)有;號(hào)結(jié)尾,這就是問(wèn)題了,直接修改,然后再運(yùn)行一下,發(fā)現(xiàn)沒(méi)錯(cuò)誤,OK了。

    如果不想直接加載,而只是想看看自己的配置文件有沒(méi)有問(wèn)題,可以直接輸入:

    Xml代碼 復(fù)制代碼 收藏代碼
    1. nginx -t 

    這可以檢查配置文件中是否有錯(cuò)。 下面我們所有的修改都假設(shè)我們修改完成后運(yùn)行了nginx -s reload進(jìn)行重新加載配置文件,請(qǐng)注意。

    一切沒(méi)問(wèn)題了,然后我們?cè)僦匦麓蜷_(kāi)http://localhost,我們看到下面的頁(yè)面:

    這時(shí),我們發(fā)現(xiàn)它并不是剛才的welcome頁(yè)面了,而是tomcat的管理頁(yè)面了,不管我們點(diǎn)擊什么鏈接都是沒(méi)問(wèn)題的,相當(dāng)于直接訪問(wèn)http://localhost:8080一樣。

    3)上面我們直接試了一個(gè)小例子,讓nginx進(jìn)行轉(zhuǎn)發(fā),即所謂的反向代理。但實(shí)際上我們的需求不會(huì)是這樣的,我們需要分文件類(lèi)型來(lái)進(jìn)行過(guò)濾,比如jsp直接給tomcat處理,因?yàn)閚ginx并不是servlet容器,沒(méi)辦法處理JSP,而html,js,css這些不需要處理的,直接給nginx進(jìn)行緩存。

    下面我們來(lái)進(jìn)行一下配置,讓JSP頁(yè)面直接給tomcat,而html,png等一些圖片和JS等直接給nginx進(jìn)行緩存。

    這時(shí)最主要用的還是location這個(gè)元素,并且涉及到一部分正則,但不難:

    Xml代碼 復(fù)制代碼 收藏代碼
    1. location ~ \.jsp$ { 
    2.         proxy_pass http://localhost:8080; 
    3.          
    4. location ~ \.(html|js|css|png|gif)$ { 
    5.     root D:/software/developerTools/server/apache-tomcat-7.0.8/webapps/ROOT; 

    我們先要去掉之前配的location /,避免全部請(qǐng)求被攔截了。

    然后我們?cè)賮?lái)看看http://localhost

    當(dāng)我們不指定jsp頁(yè)面的時(shí)候,它會(huì)出現(xiàn)找不到,因?yàn)椋藭r(shí)并沒(méi)有相應(yīng)的location匹配,所以就會(huì)有404錯(cuò)誤,這時(shí)就跳到了nginx自定義的error頁(yè)面去了。

    而當(dāng)我們用http://localhost/index.jsp去訪問(wèn)時(shí),我們看到了熟悉的頁(yè)面:

    而且圖片那些都顯示正常,因?yàn)閳D片是png的,所以直接在tomcat/webapps/ROOT目錄下直接查找,當(dāng)然,如果我們點(diǎn)擊Manager Application HOW-TO這個(gè)鏈接,我們發(fā)現(xiàn):

    它還是找不到,為什么呢?因?yàn)檫@是個(gè)html頁(yè)面,但它并不在ROOT目錄下,而是在docs目錄下,但當(dāng)我們匹配html時(shí),我們卻到ROOT目錄下去找,所以還是找不到這個(gè)頁(yè)面。

    一般情況下,如果我們需要用nginx來(lái)進(jìn)行靜態(tài)文件伺服,一般都會(huì)把所有靜態(tài)文件,html,htm,js,css等都放在同一個(gè)文件夾下,這樣就不會(huì)有tomcat這樣的情況了,因?yàn)閠omcat下的是屬于不同的項(xiàng)目,這個(gè)我們就沒(méi)辦法了。

    3)有些人會(huì)說(shuō),這些都只會(huì)找一臺(tái)服務(wù)器,但如果我們想在一臺(tái)服務(wù)器掛了的時(shí)候,自動(dòng)去找另外一臺(tái),這怎么辦?這實(shí)際上nginx都考慮到了。

    這時(shí),我們之前用的proxy_pass就有大用途了。

    我們把之前的第一個(gè)例子,即全部都代理的修改一下:

    最后修改如下:

    Xml代碼 復(fù)制代碼 收藏代碼
    1. upstream local_tomcat { 
    2.     server localhost:8080; 
    3.  
    4. server{ 
    5.         location / { 
    6.            proxy_pass http://local_tomcat; 
    7.         } 
    8.         #......其他省略 

    我們?cè)趕erver外添加了一個(gè)upstream,而直接在proxy_pass里面直接用http://+upstream的名稱來(lái)使用。

    我們還是直接來(lái)http://localhost,還是和第一個(gè)一樣的效果,所有鏈接都沒(méi)問(wèn)題,說(shuō)明我們配置正確。

    upstream中的server元素必須要注意,不能加http://,但proxy_pass中必須加。

    我們剛才說(shuō)可以在一個(gè)服務(wù)器掛了的情況下連到另外一個(gè),那怎么弄呢?

    其實(shí)很簡(jiǎn)單,在upstream中的local_tomcat中配置多一個(gè)server。比如我現(xiàn)在弄多一個(gè)jetty,端口在9999,所以我們配置如下:

    Xml代碼 復(fù)制代碼 收藏代碼
    1. upstream local_tomcat { 
    2.     server localhost:8080; 
    3.     server localhost:9999; 

    此時(shí),我們關(guān)閉tomcat,而只開(kāi)jetty。我們來(lái)運(yùn)行http://localhost看看效果:

    我們看到它請(qǐng)求到了jetty的頁(yè)面,但由于jetty的機(jī)制,這時(shí)沒(méi)有顯示jetty主頁(yè),這個(gè)我們先不管。但我們的在一個(gè)服務(wù)器掛的情況下自動(dòng)使用另外一個(gè)的功能實(shí)現(xiàn)了。

    但有時(shí)我們就不想它掛的時(shí)候訪問(wèn)另外一個(gè),而只是希望一個(gè)服務(wù)器訪問(wèn)的機(jī)會(huì)比另外一個(gè)大,這個(gè)可以在server最后加上一個(gè)weight=數(shù)字來(lái)指定,數(shù)字越大,表明請(qǐng)求到的機(jī)會(huì)越大。

    Xml代碼 復(fù)制代碼 收藏代碼
    1. upstream local_tomcat { 
    2.     server localhost:8080 weight=1
    3.     server localhost:9999 weight=5

    這時(shí)我們給了jetty一個(gè)更高的權(quán)值,讓它更有機(jī)會(huì)訪問(wèn)到,實(shí)際上當(dāng)我們刷新http://localhost訪問(wèn)的時(shí)候發(fā)現(xiàn)jetty訪問(wèn)機(jī)率大很多,tomcat幾乎沒(méi)機(jī)會(huì)訪問(wèn),一般情況下,如果我們必須這樣用,不要相關(guān)太大,以免一個(gè)服務(wù)器負(fù)載太大。

    當(dāng)然,server還有一些其他的元素,比如down表示暫時(shí)不用到該服務(wù)器等等。這些可以參考nginx的wiki。也許寫(xiě)了一大堆,有人會(huì)有問(wèn)題,那nginx怎么關(guān)閉呢?這倒是個(gè)問(wèn)題,其實(shí)直接運(yùn)行nginx -s stop就可以關(guān)閉了。

    基本上nginx的用法是這樣,深入的以后我們?nèi)绻玫皆賹W(xué)習(xí)。

    posted @ 2014-06-17 15:24 yuhaibo736 閱讀(1385) | 評(píng)論 (0)編輯 收藏

    第一步:

       1)下載jad.exe文件:http://www.varaneckas.com/jad

       2)下載jadeclipse插件:http://sourceforge.net/projects/jadclipse/files/


    第二步:
        1)解壓縮jad158g.win.zip成jad.exe,把它c(diǎn)opy至jre的bin目錄下,比如我的jre安裝到了c盤(pán)下,copy的路徑即為c:\Program Files\Java\jre6\bin(下一步配置等待net.sf.jadclipse_3.3.0.jar配置完成之后再說(shuō))
        2)找到myeclipse的安裝目錄,我的myeclipse安裝在c盤(pán)下,路徑如下:c:\ Program Files\yEclipse10。該目錄下有dropins文件,我們需要在該文件夾下,新建jad文件夾,jad文件夾下新建 features 和 plugins 兩個(gè)文件夾,把net.sf.jadclipse_3.3.0.jar 復(fù)制到兩個(gè)文件夾下,然后重啟myeclipse。

    第三步:
        1)在eclipse窗口下,點(diǎn)擊Window > Preferences > Java > JadClipse > Path to Decompiler。(設(shè)置jad的絕對(duì)路徑,如 c:\Program Files\Java\jre6\bin\jad.exe  )。Use Eclipse code formatter(overrides Jad formatting instructions)選項(xiàng)打勾,與格式化出來(lái)的代碼樣式一致。

        2)在eclipse窗口下,點(diǎn)擊Window > Preferences > Java > JadClipse > Misc,將Convert Unicode strings into ANSI strings選項(xiàng)打勾,避免反編譯后可能出現(xiàn)的中文亂碼。
    第四步:
        安裝完成后,myeclipse沒(méi)有自動(dòng)將JadClipse Class File Viewer設(shè)置成class文件的缺省打開(kāi)方式,設(shè)置方法如

    在Eclipse的Windows—> Perference—>General->Editors->File
    Associations中修改“*.class”默認(rèn)關(guān)聯(lián)的編輯器為“JadClipse Class File Viewer”。

    第五步:
        設(shè)置完成,找一個(gè)jar包中的*.class文件,myeclipse將自動(dòng)反編譯。

    posted @ 2014-05-26 16:05 yuhaibo736 閱讀(1373) | 評(píng)論 (0)編輯 收藏

    首先在網(wǎng)上下載Eclipse Class Decompiler插件: http://download.csdn.net/detail/ibm_hoojo/5250263
    下載后,解壓可以看到如下目錄,復(fù)制所有文件粘貼到你的eclipse或MyEclipse的目錄:D:\MyEclipse 6.5\dropins\eclipse或D:\eclipse\dropins\eclipse下,沒(méi)有對(duì)應(yīng)的文件夾就新建,選擇覆蓋即可。然后重新啟動(dòng)eclipse。 

    再次打開(kāi).class文件就是反編譯后的文件了

    posted @ 2014-05-21 17:14 yuhaibo736 閱讀(1116) | 評(píng)論 (0)編輯 收藏

    主站蜘蛛池模板: 成人性生交大片免费看午夜a| 在线免费观看一区二区三区| 一二三四影视在线看片免费| 免费va在线观看| 亚洲欧洲日韩不卡| 亚洲国产一区二区三区在线观看| 中文字幕乱码系列免费| 国产成人精品免费视频动漫 | 亚洲国产一成久久精品国产成人综合 | 久久亚洲美女精品国产精品| 亚洲αⅴ无码乱码在线观看性色| 99re6在线精品免费观看| 国产精品视频永久免费播放| 国产AV无码专区亚洲AV手机麻豆 | 久久午夜羞羞影院免费观看| 国产成人免费高清在线观看| 亚洲人成电影福利在线播放| 羞羞视频免费观看| 国产精品视频免费| 77777亚洲午夜久久多人| 中日韩亚洲人成无码网站| 日本高清免费观看| 免费国产成人午夜私人影视| 亚洲国产精品白丝在线观看| 二区久久国产乱子伦免费精品| 成人免费看片又大又黄| 亚洲天堂久久精品| 久久毛片免费看一区二区三区| 免费看美女被靠到爽的视频| 4444亚洲国产成人精品| 中文字幕免费在线看| 国产高清免费在线| 亚洲另类视频在线观看| 国产午夜免费高清久久影院| 国产不卡免费视频| 日本亚洲免费无线码| 18观看免费永久视频| 国产∨亚洲V天堂无码久久久| 男人和女人高潮免费网站| 女人18毛片水真多免费看| 亚洲欧洲校园自拍都市|