j2EE上传文件处理

很多黑客利用文件上传来请求服务器资源,往往我们的项目都是用的root权限,所以对上传文件的格式限制是必要的的

struts中可以利用过滤器

<interceptor-ref name="defaultStack">
<!-- 配置允许上传的文件类型,多个用","分隔 -->
<param name="fileUpload.allowedTypes">
image/bmp,image/png,image/gif,image/jpeg,image/jpg,image/x-png,image/pjpeg
</param>
<!-- 配置允许上传的文件大小,单位字节,本例为:1MB -->
<param name="fileUpload.maximumSize">10485760</param>
</interceptor-ref>

但是这个只是验证文件的后缀名,代码中也要验证

String type = FileUtils.getFileByFile(upload[i]);

下面就是fileutils的代码

  
public class FileUtils  
{  
    public final static Map<String, String> FILE_TYPE_MAP = new HashMap<String, String>();  
      
    private SAASFileUtils(){}  
    static{  
        getAllFileType();  //初始化文件类型信息  
    }  
      
    private static void getAllFileType()  
    {  
        FILE_TYPE_MAP.put("jpg", "FFD8FF"); //JPEG (jpg)  
        FILE_TYPE_MAP.put("png", "89504E47");  //PNG (png)  
        FILE_TYPE_MAP.put("gif", "47494638");  //GIF (gif)  
        FILE_TYPE_MAP.put("tif", "49492A00");  //TIFF (tif)  
        FILE_TYPE_MAP.put("bmp", "424D"); //Windows Bitmap (bmp)  
        FILE_TYPE_MAP.put("dwg", "41433130"); //CAD (dwg)  
        FILE_TYPE_MAP.put("html", "68746D6C3E");  //HTML (html)  
        FILE_TYPE_MAP.put("rtf", "7B5C727466");  //Rich Text Format (rtf)  
        FILE_TYPE_MAP.put("xml", "3C3F786D6C");  
        FILE_TYPE_MAP.put("zip", "504B0304");  
        FILE_TYPE_MAP.put("rar", "52617221");  
        FILE_TYPE_MAP.put("psd", "38425053");  //Photoshop (psd)  
        FILE_TYPE_MAP.put("eml", "44656C69766572792D646174653A");  //Email [thorough only] (eml)  
        FILE_TYPE_MAP.put("dbx", "CFAD12FEC5FD746F");  //Outlook Express (dbx)  
        FILE_TYPE_MAP.put("pst", "2142444E");  //Outlook (pst)  
        FILE_TYPE_MAP.put("xls", "D0CF11E0");  //MS Word  
        FILE_TYPE_MAP.put("doc", "D0CF11E0");  //MS Excel 注意:word 和 excel的文件头一样  
        FILE_TYPE_MAP.put("mdb", "5374616E64617264204A");  //MS Access (mdb)  
        FILE_TYPE_MAP.put("wpd", "FF575043"); //WordPerfect (wpd)   
        FILE_TYPE_MAP.put("eps", "252150532D41646F6265");  
        FILE_TYPE_MAP.put("ps", "252150532D41646F6265");  
        FILE_TYPE_MAP.put("pdf", "255044462D312E");  //Adobe Acrobat (pdf)  
        FILE_TYPE_MAP.put("qdf", "AC9EBD8F");  //Quicken (qdf)  
        FILE_TYPE_MAP.put("pwl", "E3828596");  //Windows Password (pwl)  
        FILE_TYPE_MAP.put("wav", "57415645");  //Wave (wav)  
        FILE_TYPE_MAP.put("avi", "41564920");  
        FILE_TYPE_MAP.put("ram", "2E7261FD");  //Real Audio (ram)  
        FILE_TYPE_MAP.put("rm", "2E524D46");  //Real Media (rm)  
        FILE_TYPE_MAP.put("mpg", "000001BA");  //  
        FILE_TYPE_MAP.put("mov", "6D6F6F76");  //Quicktime (mov)  
        FILE_TYPE_MAP.put("asf", "3026B2758E66CF11"); //Windows Media (asf)  
        FILE_TYPE_MAP.put("mid", "4D546864");  //MIDI (mid)  
    }  
  
    public static void main(String[] args) throws Exception  
    {  
        File f = new File("c://0_1278060916VsVS.gif");  
        if (f.exists())  
        {  
            String filetype1 = getImageFileType(f);  
            System.out.println(filetype1);  
            String filetype2 = getFileByFile(f);  
            System.out.println(filetype2);  
        }  
    }  
  

    public final static String getImageFileType(File f)  
    {  
        if (isImage(f))
        {
            try
            {
                ImageInputStream iis = ImageIO.createImageInputStream(f);
                Iterator<ImageReader> iter = ImageIO.getImageReaders(iis);
                if (!iter.hasNext())
                {
                    return null;
                }
                ImageReader reader = iter.next();
                iis.close();
                return reader.getFormatName();
            }
            catch (IOException e)
            {
                return null;
            }
            catch (Exception e)
            {
                return null;
            }
        }
        return null;
    }  
  

    public final static String getFileByFile(File file)  
    {  
        String filetype = null;  
        byte[] b = new byte[50];  
        try  
        {  
            InputStream is = new FileInputStream(file);  
            is.read(b);  
            filetype = getFileTypeByStream(b);  
            is.close();  
        }  
        catch (FileNotFoundException e)  
        {  
            e.printStackTrace();  
        }  
        catch (IOException e)  
        {  
            e.printStackTrace();  
        }  
        return filetype;  
    }  
      

    public final static String getFileTypeByStream(byte[] b)  
    {  
        String filetypeHex = String.valueOf(getFileHexString(b));  
        Iterator<Entry<String, String>> entryiterator = FILE_TYPE_MAP.entrySet().iterator();  
        while (entryiterator.hasNext()) {  
            Entry<String,String> entry =  entryiterator.next();  
            String fileTypeHexValue = entry.getValue();  
            if (filetypeHex.toUpperCase().startsWith(fileTypeHexValue)) {  
                return entry.getKey();  
            }  
        }  
        return null;  
    }  
      

    public static final boolean isImage(File file){
        boolean flag = false;
        try
        {
            BufferedImage bufreader = ImageIO.read(file);
            int width = bufreader.getWidth();
            int height = bufreader.getHeight();
            if(width==0 || height==0){
                flag = false;
            }else {
                flag = true;
            }
        }
        catch (IOException e)
        {
            flag = false;
        }catch (Exception e) {
            flag = false;
        }
        return flag;
    }
    

    public final static String getFileHexString(byte[] b)  
    {  
        StringBuilder stringBuilder = new StringBuilder();  
        if (b == null || b.length <= 0)  
        {  
            return null;  
        }  
        for (int i = 0; i < b.length; i++)  
        {  
            int v = b[i] & 0xFF;  
            String hv = Integer.toHexString(v);  
            if (hv.length() < 2)  
            {  
                stringBuilder.append(0);  
            }  
            stringBuilder.append(hv);  
        }  
        return stringBuilder.toString();  
    }  
}

这样即使用户该课后缀也不用怕了。我们的网站被黑客上传了木马,分享一下方便下次查阅。



转载于:https://my.oschina.net/amicable/blog/114399

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值