随笔-31  评论-7  文章-0  trackbacks-0
  2008年8月16日

内容如下:

 

Code

大家注意身体啊 



--------------------------
09博客园纪念T恤
新闻:网站评测:搜狐博客 VS 我烧网
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/08/25/1553578.html
posted @ 2009-08-25 13:33 破名超难起 阅读(151) | 评论 (0)编辑 收藏

防盗链原理:

http标准协议中有专门的字段记录referer

一来可以追溯上一个入站地址是什么

二来对于资源文件,可以跟踪到包含显示他的网页地址是什么。

因此所有防盗链方法都是基于这个Referer字段

网上比较多的2种

一种是使用apache文件FileMatch限制,在httpd.conf中增加 ( 其实也可以将把下面的语句存成一个.htaccess文件),并放到你的网站的根目录(就是www/html目录),这样子别人就没有办法盗连你的东东了~~

SetEnvIfNoCase Referer "^http://yahoo.com/" local_ref=1

Order Allow,Deny
Allow from env=local_ref
Allow from 127.0.0.1


这种很方便禁止非允许访问URL引用各种资源文件

请大家注意,把第一句"^http://yahoo.com/"改为你的网站,比如我的网站是: http://www.linji.cn
我应该这么写的
"^http://www.linji.cn/"

第二种是使用rewrite,需要增加apache的mode_rewrite,支持.htaccess文件目录权限限制
在虚拟主机根目录增加.htaccess文件,描述从定向,把非本地地址refer的图片文件都从定向到警告图片或者警告网页上。

首先要确认你的服务器或空间的服务器解译引擎为Apache2,还有支持.htaccess客户设置文件,
如果你有自己的服务器就请先对./conf/httpd.conf 文件做以下修改
找到:#LoadModule rewrite_module modules/mod_rewrite.so
把前面的 # 给去丢
找到等一个 AllowOverride None 改为 AllowOverride All
重启Apache2服务器

接下就是做一个 .htaccess 文件了,其 .htaccess 文件内容为

RewriteEngine on
RewriteCond %{HTTP_REFERER} !^http://aaoo.net/.*$ [NC]
RewriteCond %{HTTP_REFERER} !^http://aaoo.net$ [NC]
RewriteCond %{HTTP_REFERER} !^http://www.aaoo.net/.*$ [NC]
RewriteCond %{HTTP_REFERER} !^http://www.aaoo.net$ [NC]
RewriteRule .*.(jpg|jpeg|gif|png|bmp|rar|zip|exe)$ http://down.yoyo.com.ru/err.html [R,NC]

其中有色的地方都是要改为你的:
红色:就是改为你提供下载页面的地址,也就是只有通过这个地址才可以下载你所提供的东东。
蓝色:就是要保护文件的扩展名(以|分开),也就是说以这些为扩展名的文件只有通过红色的地址才可以访问。
绿色:如果不是通过红色的地址访问蓝色这些为扩展名的文件时就回重定向到绿色地址上。

这个方法有个好处是,不同的虚拟主机用不同的描述定义。

接下就是怎么用 .htaccess 文件来实现防盗链了。
首先要在空间上建两个目录(当然目录名随你),一个为 web 另一个为 down ,
web 是用来放下载页面的(或下载程序),down 当然就是放你提供的东东的啦,
把 .htaccess 文件的红色部分改一下,改为http://你的域名/web。蓝色部分
改为你要保护文件的扩展名。绿色部分改为http://你的域名/web。改后保存
.htaccess 文件把它上传到 down 目录。

还有第三种:

我在解决plog禁止盗链的时候,发现个问题,也算个好方法。
plog把所有资源都自己管理起来,用resserver.php来动态显示,这样统一的入口方便添加权限操作。
同时造成上面2种方法无法使用,因为不再是apache直接访问资源文件,而是php通过文件读取。

因此只能在代码中做手脚:在读取资源文件输出之前,加如下判断代码


引用

$referer = $_SERVER['HTTP_REFERER'];
$selfurl = $_SERVER['HTTP_HOST'];
if(false == strpos($referer,$selfurl))
{
echo '非法盗链!';
exit(1);
}





这里有些偷懒,直接看引用地址中是否包含host地址,不过原理就是这样,判断referer是否是本站地址。

我们常常在下载的时候,也碰到盗链网站无法下载,报盗链的问题。要下载这类文件最简单的方法就是改referer

比方flashget中,网址下面的"引用"一栏中,直接填写下载地址就可以了。



--------------------------
09博客园纪念T恤
新闻:微软:不一样的PowerPoint 2010
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/08/21/1551756.html
posted @ 2009-08-21 23:30 破名超难起 阅读(326) | 评论 (0)编辑 收藏

这两天完善了一下视频转换这个东西,以前做的那套东西上传完之后就开始转换,无法适应大并发量下的视频转换(我觉得同时有10个ffmpeg进程在转视频服务器肯定要挂掉),所以我用了另一套方案,视频上传之后先不转换,把视频的基本信息存到数据库中,然后由程序定时的从数据库中读取数据,依次转换视频。具体做法是:1、上传文件,将文件名存入数据库,同时在数据库标明videostat字段为0(表示未转换)

  2、通过程序,每隔30秒(根据不同情况可以改变)取出一个未转换(videostat=0)且失败次数小于5(confailtime<5)的纪录

  3、开始转换视频,这里要先将数据库中videostat字段改为2(表示正在转换)不然30秒钟转换不完下个进程又会读到这条纪录开始转换......

  4、等待转换进程结束,如果成功将相应纪录的videostat字段的值改为1(表示转换成功),若转换失败则将失败次数字段加一(confailtime=confailtime+1)

  在鼓捣这东西的过程中,遇到了一个问题,如果一个进程先执行p.waitFor();方法而后输出命令行中的结果是不行的,即:

Code

如果这样执行的话进程会挂起,无法继续下午,而正确的方法是先读取命令行的数据,再来waitFor();

还有一点需要注意的是获得命令行的输出结果先要从错误流中获得,即(ErrorStream),而非从输入流(InputStream)中获得,很有用的经验。



--------------------------
09博客园纪念T恤
新闻:自由软件基金会列举Windows 7之七宗罪
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/08/04/1538824.html
posted @ 2009-08-04 17:45 破名超难起 阅读(265) | 评论 (0)编辑 收藏

很久不在这里发帖子了,最近在家闲来无事,想到转视频的那东西又要做了,遂翻出以前的帖子,看到一年前丰哥让我做一下文件上传的进度条....额~~那就做一下吧。

东西很简单,主要用到commons-fileupload,其中有一个progressListener的接口,该接口可以实现实时更新已上传文件的大小,有了这个还说什么呢?

给出代码

代码

 

然后在上传得servlet或action中加入这样一段代码,就可以把自定义的progressListener添加进去

 

代码

 

最后就是通过js来不断的访问另一个servlet来实时返回上传状态就可以了,限于篇幅我就不再贴代码了,有兴趣的读者可以自己下载来看。

 代码下载(目标另存为就行了)



--------------------------
09博客园纪念T恤
新闻:网速调查报告:韩国互联网网速全球居首
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/08/03/1537870.html
posted @ 2009-08-03 19:46 破名超难起 阅读(4886) | 评论 (7)编辑 收藏
http://family168.com/oa/springsecurity/html/index.html
posted @ 2009-07-19 18:28 破名超难起 阅读(195) | 评论 (0)编辑 收藏

package lc.util;

import java.math.BigDecimal;

public class MathHelper {
 private static final int DEF_DIV_SCALE = 10;

 private MathHelper() {

 }

 /**
  * 提供精确的加法运算。
  *
  * @param v1
  *            被加数
  * @param v2
  *            加数
  * @return 两个参数的和
  */
 public static double add(double v1, double v2) {
  BigDecimal b1 = new BigDecimal(Double.toString(v1));
  BigDecimal b2 = new BigDecimal(Double.toString(v2));
  return b1.add(b2).doubleValue();
 }

 /**
  * 提供精确的减法运算。
  *
  * @param v1
  *            被减数
  * @param v2
  *            减数
  * @return 两个参数的差
  */
 public static double sub(double v1, double v2) {
  BigDecimal b1 = new BigDecimal(Double.toString(v1));
  BigDecimal b2 = new BigDecimal(Double.toString(v2));
  return b1.subtract(b2).doubleValue();
 }

 /**
  * 提供精确的乘法运算。
  *
  * @param v1
  *            被乘数
  * @param v2
  *            乘数
  * @return 两个参数的积
  */
 public static double mul(double v1, double v2) {
  BigDecimal b1 = new BigDecimal(Double.toString(v1));
  BigDecimal b2 = new BigDecimal(Double.toString(v2));
  return b1.multiply(b2).doubleValue();
 }

 /**
  * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到 小数点以后10位,以后的数字四舍五入。
  *
  * @param v1
  *            被除数
  * @param v2
  *            除数
  * @return 两个参数的商
  */
 public static double div(double v1, double v2) {
  return div(v1, v2, DEF_DIV_SCALE);
 }

 /**
  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指 定精度,以后的数字四舍五入。
  *
  * @param v1
  *            被除数
  * @param v2
  *            除数
  * @param scale
  *            表示表示需要精确到小数点以后几位。
  * @return 两个参数的商
  */

 public static double div(double v1, double v2, int scale) {
  if (scale < 0) {
   throw new IllegalArgumentException(
     "The scale must be a positive integer or zero");
  }
  BigDecimal b1 = new BigDecimal(Double.toString(v1));
  BigDecimal b2 = new BigDecimal(Double.toString(v2));
  return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
 }

 /**
  * 提供精确的小数位四舍五入处理。
  *
  * @param v
  *            需要四舍五入的数字
  * @param scale
  *            小数点后保留几位
  * @return 四舍五入后的结果
  */
 public static double round(double v, int scale) {
  if (scale < 0) {
   throw new IllegalArgumentException(
     "The scale must be a positive integer or zero");
  }
  BigDecimal b = new BigDecimal(Double.toString(v));
  BigDecimal one = new BigDecimal("1");
  return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
 }
}



--------------------------
09博客园纪念T恤
新闻:王建宙台湾布道TD:痛快,一起努力的感觉
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/05/20/1469589.html
posted @ 2009-05-20 17:13 破名超难起 阅读(305) | 评论 (0)编辑 收藏

import java.sql.*;

public class Access

{

public static void main(String args[])

{

try

{

String strurl="jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=books.mdb";

Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

Connection conn=DriverManager.getConnection(strurl) ;

Statement stmt=conn.createStatement();

ResultSet rs=stmt.executeQuery("select * from books");

if(rs.next())

{

System.out.println(rs.getString("简介"));

}

}catch(Exception e)

{

System.out.println(e);

}

}

}



--------------------------
09博客园纪念T恤
新闻:微软正式对Word禁售令提起上诉 称法官不懂法
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/05/08/1452661.html
posted @ 2009-05-08 15:08 破名超难起 阅读(176) | 评论 (0)编辑 收藏

又一个新闻发布......比以前的更加人性化了,用到了Struts2、Struts2的JSON插件,前台js用了Jquery库,自己看吧。欢迎大家提出自己的宝贵意见。

关于显示新闻的功能我还没有找到一个合适的AJAX表现形式,所以还没有完成,欢迎大家给我个建议

 

点击下载源码



--------------------------
09博客园纪念T恤
新闻:IBM 2009年北美裁员近1万人
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2009/03/16/1413631.html
posted @ 2009-03-16 17:48 破名超难起 阅读(192) | 评论 (0)编辑 收藏

     最近搞的一个通讯录想要加一个Ajax的自动完成功能,看起来功能虽小,可给用户的体验会改进不少。在一个介绍了几十种java的Ajax框架的网页里面,我找到了AjaxTags这个小东西,开始了我的第一次Ajax之旅。

     从AjaxTags的官方网站上面http://ajaxtags.sourceforge.net/可以下载到其最新的版本,目前是AjaxTags1.3顺便下载了一个官方的小例子看了看,确实很好阿,例子中使用Ajax完成了11种功能,然而我需要的是自动完成(autocomplete)部分的代码,所以重点研究这一部分

      jsp页面中,首先当然是要添加AjaxTags的标签支持,需要如下语句

Code

     然后在页面中加入如下的标签

 

Code

    在官方的例子中使用的是Servlet来完成Ajax,而对于使用struts就不适用了,后面说这个问题。

    在 autocomplete.view对应的Servlet类中需要建立xml来供页面调取,代码如下

Code
    其实还是很简单的,接下来看CarService的代码吧,重点其实只有一段,然后在下面显示出自动提示,于是可以把刚才的那个ajax标签修改如下
Code

例子看完了,开始实际操作吧,在我的页面中,需要通过一个名为"name"的文本框输入要查询的人的姓名

Code

 接下来是我的Action,在写Action的时候,我以为只需要把原来Servlet继承的BaseAjaxServlet改为BaseAjaxAction就可以了,可后来才发现,jar包中根本就没有BaseAjaxAction这个类,无语,去官方网站上看了后才知道,在1.2更新到1.3的时候,把对Struts的支持去掉了,如果想支持Struts的话需要建立自己的BaseAjaxAction

(Struts removed, to use it create your own BaseAjaxAction.java and implement BaseAjaxXmlAction then just call xml = AjaxActionHelper.invoke(this, request, response);)

下载了一份AjaxTags的源码来看,原来AjaxActionHelper.invoke();这个方法需要调用Action中的getXmlContent方法来完成xml的写入,那就好说了,代码如下:

Code
剩下工作就是在struts-config.xml中配置对应的action,在spring中配置对应的bean就ok拉

 



--------------------------
09博客园纪念T恤
新闻:Office 2010双拳出击加强反盗版
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2008/09/22/1295661.html
posted @ 2008-09-22 09:42 破名超难起 阅读(200) | 评论 (0)编辑 收藏

我一直有通宵下东西的习惯,可又不忍心让笔记本下载完成后一直等到我睡醒,所以我经常用迅雷给我们提供的下载完成后自动关机这个功能。

然而现在迅雷运行在了虚拟机里面,这就郁闷了,即使自动关机也只能关掉一个虚拟机的进程,无奈我想到可不可以用shell程序来监测虚拟机的进程,当他关闭后就运行关机的命令,经过测试,果然成功了,具体代码如下:

Code

将代码保存在shutdown.sh文件中

使用起来也很方便,用"ps ux"找到vbox运行的进程,将其对应的time command值作为参数输入进来,例如我的是:

lichao   10659 91.7 52.0 1224284 1079860 ?     Sl   21:49  11:01 /opt/VirtualBox-1.6.4/VirtualBox -comment winxp -startvm 5e04c66f-82f7-4df0-0f92-8b9113be6f2

则执行上述脚本文件:

./ shutdown.sh /opt/VirtualBox-1.6.4/VirtualBox -comment winxp -startvm 5e04c66f-82f7-4df0-0f92-8b9113be6f2

监测开始

当虚拟机关机后命令行出现如下提示:

Done..shuting down in 60 seconds.

60秒后就会关机拉,如果你还不想关机,可以Ctrl+Alt+C停止当前任务,再进行其他操作,怎么样,挺好使的

--------------------------
09博客园纪念T恤
新闻:中国联通:国际通讯已恢复至震前水平
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2008/08/21/1273554.html
posted @ 2008-08-21 22:25 破名超难起 阅读(506) | 评论 (0)编辑 收藏
查看软件xxx安装内容
  • dpkg -L xxx
查找软件
  • apt-cache search 正则表达式
查找文件属于哪个包
  • dpkg -S filename
    apt-file search filename
查询软件xxx依赖哪些包
  • apt-cache depends xxx


查询软件xxx被哪些包依赖
  • apt-cache rdepends xxx
增加一个光盘源
  • sudo apt-cdrom add
系统升级
  • sudo apt-get update
    sudo apt-get upgrade
    sudo apt-get dist-upgrade
清除所以删除包的残余配置文件
  • dpkg -l |grep ^rc|awk '{print $2}' |tr ["n"] [" "]|sudo xargs dpkg -P -
编译时缺少h文件的自动处理
  • sudo auto-apt run ./configure
查看安装软件时下载包的临时存放目录
  • ls /var/cache/apt/archives
备份当前系统安装的所有包的列表
  • dpkg --get-selections | grep -v deinstall > ~/somefile
从上面备份的安装包的列表文件恢复所有包
  • dpkg --set-selections < ~/somefile
    sudo dselect
清理旧版本的软件缓存
  • sudo apt-get autoclean
清理所有软件缓存
  • sudo apt-get clean
删除系统不再使用的孤立软件
  • sudo apt-get autoremove
查看包在服务器上面的地址
  • apt-get -qq --print-uris install ssh | cut -d' -f2
系统 查看内核
  • uname -a
查看Ubuntu版本
  • cat /etc/issue
查看内核加载的模块
  • lsmod
查看PCI设备
  • lspci
查看USB设备
  • lsusb
查看网卡状态
  • sudo ethtool eth0
查看CPU信息
  • cat /proc/cpuinfo
显示当前硬件信息
  • lshw
硬盘 查看硬盘的分区
  • sudo fdisk -l
查看IDE硬盘信息
  • sudo hdparm -i /dev/hda
查看STAT硬盘信息
  • sudo hdparm -I /dev/sda

    sudo apt-get install blktool
    sudo blktool /dev/sda id
查看硬盘剩余空间
  • df -h
    df -H
查看目录占用空间
  • du -hs 目录名
优盘没法卸载
  • sync
    fuser -km /media/usbdisk
内存 查看当前的内存使用情况
  • free -m
进程 查看当前有哪些进程
  • ps -A
中止一个进程
  • kill 进程号(就是ps -A中的第一列的数字)
    或者 killall 进程名
强制中止一个进程(在上面进程中止不成功的时候使用)
  • kill -9 进程号
    或者 killall -9 进程名
图形方式中止一个程序
  • xkill 出现骷髅标志的鼠标,点击需要中止的程序即可
查看当前进程的实时状况
  • top
查看进程打开的文件
  • lsof -p
ADSL 配置 ADSL
  • sudo pppoeconf
ADSL手工拨号
  • sudo pon dsl-provider
激活 ADSL
  • sudo /etc/ppp/pppoe_on_boot
断开 ADSL
  • sudo poff
查看拨号日志
  • sudo plog
如何设置动态域名
  • #首先去 http://www.3322.org 申请一个动态域名
    #然后修改 /etc/ppp/ip-up 增加拨号时更新域名指令
    sudo vim /etc/ppp/ip-up
    #在最后增加如下行
    w3m -no-cookie -dump 'http://username:password@members.3322.org/dyndns/update?system=dyndns&hostname=yourdns.3322.org'
网络 根据IP查网卡地址
  • arping IP地址
查看当前IP地址
  • ifconfig eth0 |awk '/inet/ {split($2,x,":");print x[2]}'
查看当前外网的IP地址
  • w3m -no-cookie -dump www.ip138.com|grep -o '[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}'
    w3m -no-cookie -dump www.123cha.com|grep -o '[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}'
    w3m -no-cookie -dump ip.loveroot.com|grep -o '[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}'
查看当前监听80端口的程序
  • lsof -i :80
查看当前网卡的物理地址
  • arp -a | awk '{print $4}'
    ifconfig eth0 | head -1 | awk '{print $5}'
立即让网络支持nat
  • echo 1 | sudo tee /proc/sys/net/ipv4/ip_forward
    sudo iptables -t nat -I POSTROUTING -j MASQUERADE
查看路由信息
  • netstat -rn
    sudo route -n
手工增加删除一条路由
  • sudo route add -net 192.168.0.0 netmask 255.255.255.0 gw 172.16.0.1
    sudo route del -net 192.168.0.0 netmask 255.255.255.0 gw 172.16.0.1
修改网卡MAC地址的方法
  • sudo ifconfig eth0 down #关闭网卡
    sudo ifconfig eth0 hw ether 00:AA:BB:CC:DD:EE #然后改地址
    sudo ifconfig eth0 up #然后启动网卡
统计当前IP连接的个数
  • netstat -na|grep ESTABLISHED|awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -r -n
    netstat -na|grep SYN|awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -r -n
统计当前20000个IP包中大于100个IP包的IP地址
  • tcpdump -tnn -c 20000 -i eth0 | awk -F "." '{print $1"."$2"."$3"."$4}' | sort | uniq -c | sort -nr | awk ' $1 > 100 '
屏蔽IPV6
  • echo "blacklist ipv6" | sudo tee /etc/modprobe.d/blacklist-ipv6
服务 添加一个服务
  • sudo update-rc.d 服务名 defaults 99
删除一个服务
  • sudo update-rc.d 服务名 remove
临时重启一个服务
  • /etc/init.d/服务名 restart
临时关闭一个服务
  • /etc/init.d/服务名 stop
临时启动一个服务
  • /etc/init.d/服务名 start
设置 配置默认Java使用哪个
  • sudo update-alternatives --config java
修改用户资料
  • sudo chfn userid
给apt设置代理
  • export http_proxy=http://xx.xx.xx.xx:xxx
修改系统登录信息
  • sudo vim /etc/motd
中文 转换文件名由GBK为UTF8
  • sudo apt-get install convmv
    convmv -r -f cp936 -t utf8 --notest --nosmart *
批量转换src目录下的所有文件内容由GBK到UTF8
  • find src -type d -exec mkdir -p utf8/{} ;
    find src -type f -exec iconv -f GBK -t UTF-8 {} -o utf8/{} ;
    mv utf8/* src
    rm -fr utf8
转换文件内容由GBK到UTF8
  • iconv -f gbk -t utf8 $i > newfile
转换 mp3 标签编码
  • sudo apt-get install python-mutagen
    find . -iname “*.mp3” -execdir mid3iconv -e GBK {} ;
控制台下显示中文
  • sudo apt-get install zhcon
    使用时,输入zhcon即可
文件 快速查找某个文件
  • whereis filename
  • find 目录 -name 文件名
查看文件类型
  • file filename
显示xxx文件倒数6行的内容
  • tail -n 6 xxx
让tail不停地读地最新的内容
  • tail -n 10 -f /var/log/apache2/access.log
查看文件中间的第五行(含)到第10行(含)的内容
  • sed -n '5,10p' /var/log/apache2/access.log
查找包含xxx字符串的文件
  • grep -l -r xxx .
查找关于xxx的命令
  • apropos xxx
    man -k xxx
通过ssh传输文件
  • scp -rp /path/filename username@remoteIP:/path #将本地文件拷贝到服务器上
    scp -rp username@remoteIP:/path/filename /path #将远程文件从服务器下载到本地
查看某个文件被哪些应用程序读写
  • lsof 文件名
把所有文件的后辍由rm改为rmvb
  • rename 's/.rm$/.rmvb/' *
把所有文件名中的大写改为小写
  • rename 'tr/A-Z/a-z/' *
删除特殊文件名的文件,如文件名:--help.txt
  • rm -- --help.txt 或者 rm ./--help.txt
查看当前目录的子目录
  • ls -d */. 或 echo */.
将当前目录下最近30天访问过的文件移动到上级back目录
  • find . -type f -atime -30 -exec mv {} ../back ;
将当前目录下最近2小时到8小时之内的文件显示出来
  • find . -mmin +120 -mmin -480 -exec more {} ;
删除修改时间在30天之前的所有文件
  • find . -type f -mtime +30 -mtime -3600 -exec rm {} ;
查找guest用户的以avi或者rm结尾的文件并删除掉
  • find . -name '*.avi' -o -name '*.rm' -user 'guest' -exec rm {} ;
查找的不以java和xml结尾,并7天没有使用的文件删除掉
  • find . ! -name *.java ! -name ‘*.xml’ -atime +7 -exec rm {} ;
统计当前文件个数
  • ls /usr/bin|wc -w
统计当前目录个数
  • ls -l /usr/bin|grep ^d|wc -l
显示当前目录下2006-01-01的文件名
  • ls -l |grep 2006-01-01 |awk '{print $8}'
压缩 解压缩 xxx.tar.gz
  • tar -zxvf xxx.tar.gz
解压缩 xxx.tar.bz2
  • tar -jxvf xxx.tar.bz2
压缩aaa bbb目录为xxx.tar.gz
  • tar -zcvf xxx.tar.gz aaa bbb
压缩aaa bbb目录为xxx.tar.bz2
  • tar -jcvf xxx.tar.bz2 aaa bbb
Nautilus 显示隐藏文件
  • Ctrl+h
显示地址栏
  • Ctrl+l
特殊 URI 地址
  • * computer:/// - 全部挂载的设备和网络
    * network:/// - 浏览可用的网络
    * burn:/// - 一个刻录 CDs/DVDs 的数据虚拟目录
    * smb:/// - 可用的 windows/samba 网络资源
    * x-nautilus-desktop:/// - 桌面项目和图标
    * file:/// - 本地文件
    * trash:/// - 本地回收站目录
    * ftp:// - FTP 文件夹
    * ssh:// - SSH 文件夹
    * fonts:/// - 字体文件夹,可将字体文件拖到此处以完成安装
    * themes:/// - 系统主题文件夹
查看已安装字体
  • 在nautilus的地址栏里输入”fonts:///“,就可以查看本机所有的fonts
程序 详细显示程序的运行信息
  • strace -f -F -o outfile <cmd>
日期和时间 设置日期
  • #date -s mm/dd/yy
设置时间
  • #date -s HH:MM
将时间写入CMOS
  • hwclock --systohc
读取CMOS时间
  • hwclock --hctosys
从服务器上同步时间
  • sudo ntpdate time.nist.gov
    sudo ntpdate time.windows.com
控制台 不同控制台间切换
  • Ctrl + ALT + ←
    Ctrl + ALT + →
指定控制台切换
  • Ctrl + ALT + Fn(n:1~7)
控制台下滚屏
  • SHIFT + pageUp/pageDown
控制台抓图
  • setterm -dump n(n:1~7)
数据库 mysql的数据库存放在地方
  • /var/lib/mysql
从mysql中导出和导入数据
  • mysqldump 数据库名 > 文件名 #导出数据库
    mysqladmin create 数据库名 #建立数据库
    mysql 数据库名 < 文件名 #导入数据库
忘了mysql的root口令怎么办
  • sudo /etc/init.d/mysql stop
    sudo mysqld_safe --skip-grant-tables &
    sudo mysqladmin -u user password 'newpassword''
    sudo mysqladmin flush-privileges
修改mysql的root口令
  • sudo mysqladmin -uroot -p password '你的新密码'
其它 下载网站文档
  • wget -r -p -np -k http://www.21cn.com
    · -r:在本机建立服务器端目录结构;
    · -p: 下载显示HTML文件的所有图片;
    · -np:只下载目标站点指定目录及其子目录的内容;
    · -k: 转换非相对链接为相对链接。
如何删除Totem电影播放机的播放历史记录
  • rm ~/.recently-used
如何更换gnome程序的快捷键
  • 点击菜单,鼠标停留在某条菜单上,键盘输入任意你所需要的键,可以是组合键,会立即生效;
    如果要清除该快捷键,请使用backspace
vim 如何显示彩色字符
  • sudo cp /usr/share/vim/vimcurrent/vimrc_example.vim /usr/share/vim/vimrc
如何在命令行删除在会话设置的启动程序
  • cd ~/.config/autostart
    rm 需要删除启动程序
如何提高wine的反应速度 sudo sed -ie '/GBK/,/^}/d' /usr/share/X11/locale/zh_CN.UTF-8/XLC_LOCALE

--------------------------
09博客园纪念T恤
新闻:分析称RSS阅读器是Web 1.0工具 已逐渐被抛弃
网站导航: 博客园首页  个人主页  新闻  社区  博问  闪存  找找看
文章来源:http://www.cnblogs.com/xiaoao808/archive/2008/08/20/1272372.html
posted @ 2008-08-20 16:27 破名超难起 阅读(125) | 评论 (0)编辑 收藏
Hibernate获取数据的方式有不同的几种,其与缓存结合使用的效果也不尽相同,而Hibernate中具体怎么使用缓存其实是我们很关心的一个问题,直接涉及到性能方面。
缓 存在Hibernate中主要有三个方面:一级缓存、二级缓存和查询缓存;一级缓存在Hibernate中对应的即为session范围的缓存,也就是当 session关闭时缓存即被清除,一级缓存在Hibernate中是不可配置的部分;二级缓存在Hibernate中对应的即为 SessionFactory范围的缓存,通常来讲SessionFactory的生命周期和应用的生命周期相同,所以可以看成是进程缓存或集群缓存,二 级缓存在Hibernate中是可以配置的,可以通过class-cache配置类粒度级别的缓存(class-cache在class中数据发生任何变 化的情况下自动更新),同时也可通过collection-cache配置集合粒度级别的缓存(collection-cache仅在 collection中增加了元素或者删除了元素的情况下才自动更新,也就是当collection中元素发生值的变化的情况下它是不会自动更新的),缓 存自然会带来并发的访问问题,这个时候相应的就要根据应用来设置缓存所采用的事务隔离级别,和数据库的事务隔离级别概念基本一样,没什么多介绍的, ^_^;查询缓存在Hibernate同样是可配置的,默认是关闭的,可以通过设置cache.use_ query_cache为true来打开查询缓 存。根据缓存的通常实现策略,我们可以来理解Hibernate的这三种缓存,缓存的实现通过是通过key/value的Map方式来实现,在 Hibernate的一级、二级和查询缓存也同样如此,一级、二级缓存使用的key均为po的主键ID,value即为po实例对象,查询缓存使用的则为 查询的条件、查询的参数、查询的页数,value有两种情况,如果采用的是select po.property这样的方式那么value为整个结果集,如采用的是from这样的方式那么value为获取的结果集中各po对象的主键ID,这样 的作用很明显,节省内存,^_^
简单介绍完Hibernate的缓存后,再结合Hibernate的获取数据方式来说明缓存的具体使用方式,在Hibernate中获取数据常用的方式主要有四种:Session.load、Session.get、Query.list、Query.iterator。
1、Session.load
      在执行session.load时,Hibernate首先从当前session的一级缓存中获取id对应的值,在获取不到的情况下,将根据该对象是否配 置了二级缓存来做相应的处理,如配置了二级缓存,则从二级缓存中获取id对应的值,如仍然获取不到则还需要根据是否配置了延迟加载来决定如何执行,如未配 置延迟加载则从数据库中直接获取,在从数据库获取到数据的情况下,Hibernate会相应的填充一级缓存和二级缓存,如配置了延迟加载则直接返回一个代 理类,只有在触发代理类的调用时才进行数据库查询的操作。
      在这样的情况下我们就可以看到,在session一直打开的情况下,要注意在适当的时候对一级缓存进行刷新操作,通常是在该对象具有单向关联维护的时候, 在Hibernate中可以使用象session.clear、session.evict的方式来强制刷新一级缓存。
      二级缓存则在数据发生任何变化(新增、更新、删除)的情况下都会自动的被更新。
2、Session.get
      在执行Session.get时,和Session.load不同的就是在当从缓存中获取不到时,直接从数据库中获取id对应的值。
3、Query.list
      在执行Query.list时,Hibernate的做法是首先检查是否配置了查询缓存,如配置了则从查询缓存中查找key为查询语句+查询参数+分页条 件的值,如获取不到则从数据库中进行获取,从数据库获取到后Hibernate将会相应的填充一级、二级和查询缓存,如获取到的为直接的结果集,则直接返 回,如获取到的为一堆id的值,则再根据id获取相应的值(Session.load),最后形成结果集返回,可以看到,在这样的情况下,list也是有 可能造成N次的查询的。
      查询缓存在数据发生任何变化的情况下都会被自动的清空。
4、Query.iterator
      在执行Query.iterator时,和Query.list的不同的在于从数据库获取的处理上,Query.iterator向数据库发起的是 select id from这样的语句,也就是它是先获取符合查询条件的id,之后在进行iterator.next调用时才再次发起session.load的调用获取实 际的数据。
      可见,在拥有二级缓存并且查询参数多变的情况下,Query.iterator会比Query.list更为高效。

这 四种获取数据的方式都各有适用的场合,要根据实际情况做相应的决定,^_^,最好的方式无疑就是打开show_sql选项看看执行的情况来做分析,系统结 构上只用保证这种调整是容易实现的就好了,在cache这个方面的调整自然是非常的容易,只需要调整配置文件里的设置,而查询的方式则可对外部进行屏蔽, 这样要根据实际情况调整也非常容易。

推荐三篇关于Hibernate缓存机制介绍的文章:
http://gocom.primeton.com/blog/index.php?op=ViewArticle&articleId=467&blogId=37&src=jdon&srcforum=62
http://club.gamvan.com/club/clubPage.jsp?ccStyle=0&tID=10456&ccID=37
http://www.devx.com/dbzone/Article/29685/1954?pf=true
文章来源:http://www.cnblogs.com/xiaoao808/archive/2008/08/16/1269160.html
posted @ 2008-08-16 11:03 破名超难起 阅读(81) | 评论 (0)编辑 收藏