便便代码人生

关注技术, 偶尔动动手

bianbian.org

[呜]我是电器杀手

Posted by bianbian on 2006-12-03 19:57


本文Tags:

笔记本硬盘坏了、电池废了、显示屏拆了然后出问题,那是很早很早以前的事了
实验室的显示器烧了,主机挂了,那是很早以前的事了(一个星期前?)
mp3摔了,可怜的M6刮花了,那是几天前的事了
然而今天,可怜的Nokia 6600,那可怜的1、4、7三个键废了,于是沦落为只能接电话和打电话本里的号码了
唯一完好的psp,好像还是因为被噓噓抢去了逃过此劫。。。。。。
搜了一下,发现一个好帖子,引用一下:

故障二:
[故障现象] 某几个按键同时失灵(包括2,5,8键;1,4,7键;通话,挂机,0,C键的同时失灵);
[故障原因] 排线尾插接触点处有灰尘或由于手机遭到剧烈碰撞造成接触点出现变形或错位
[解决办法] 仔细观察图B的1处的接触弹簧是否有变形,如果有,可用尖嘴钳矫正;另外用酒精棉花棒小心清洗图B的1和2处,清洗时注意不要留下棉花纤维,待干后将两块部件垂直合上,捎微用力按几下,这样有助于磨除氧化物,使接触点更紧密.然后按照拆机的反程序装好,螺丝拧紧即可.
[防灰技巧] 我们可以发现手机尾部的排线尾插处其实很容易进灰,我们可以在装机前在那地方预先贴一片双面胶,再把该部件卡入手机外壳内上再螺丝,这样可以有效防止灰尘入侵.

全文在这里:我用6600出现过的故障现象和维修方法 (作者bluebox)

22:35补记:拆开来擦了擦灰,好了!哈哈哈。想起小时候拆收音机装回去多个零件也能用。。。哈哈

标签:

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Not IT | 3 Comments »

[原]Java正则表达式获取匹配结果

Posted by bianbian on 2006-12-02 22:41


本文Tags: ,

  1. Pattern p = Pattern.compile("正则表达式");
  2. Matcher m = p.matcher("预匹配的字符串");
  3. if(m.matches()) {
  4.     m.group(1); //匹配第1项
  5.     m.group(2); //匹配第2项
  6. }

有关正则表达式语法,请参考:文档 Document

标签: ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Java, Technology | No Comments »

[呜]最近真是背,咳。。。。

Posted by bianbian on 2006-11-27 17:16


本文Tags:

先是显示器烧了;然后主机挂了,拿去修好回来打不到车,在风雨中抖了一小时。
更郁闷的是,申请招行信用卡被拒了;young卡又像被阉的信用卡(甚至丢了被他人消费损失都是自己的,已经不是信用卡了)不想办。。。。
工行网银又那么不安全,还得自己掏钱买U盾,去死吧。。。。
。。。。。。
命背不能怪社会,喝水没呛着,谢天谢地。。。。

标签:

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Not IT | 5 Comments »

[原]postgreSQL 数据库备份和恢复

Posted by bianbian on 2006-11-19 17:30


本文Tags: , , ,

备份:
./pg_dump -U 用户名 -c -Fp 数据库名 -f 文件.sql
恢复:
./psql -U 用户名 < 文件.sql

标签: , , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Database, Technology | No Comments »

[怒]南京电信太无耻了

Posted by bianbian on 2006-11-17 15:46


本文Tags:

居然用Squid做代理缓存了,难怪这段时间总是第一次打开网页打不开。更无耻的是,这样还要限速限流量,简直是无法无天。

错误
您所请求的网址(URL)无法获取
当尝试读取以下网址(URL)时:
发生了下列的错误:
Connection Failed
连接失败
系统返回以下内容:
(110) Connection timed outThe remote host or network may be down. Please try the request again.
您要连结的网络服务器或网络可能发生故障。请稍后再试。
本缓存服务器管理员:webmaster

Generated Fri, 17 Nov 2006 07:42:32 GMT by squid217 (squid/2.5.STABLE14)

标签:

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Uncategorized | 4 Comments »

[嗯]森海塞尔PX200寄到了

Posted by bianbian on 2006-11-13 23:23


本文Tags: ,

包装很好,卖家用的是硬盒。经过这几次网购,淘宝二钻以上的卖家(当然要没有虚假信用)绝对是可以相信的!
另外,请教了一些朋友,关于煲机,说要听收音机无台的频道,要听不同的频段,低沉的尖锐的都要听个遍。。。。
PX200是一款可折叠式的耳机,它采用了森海塞尔独特设计的可折叠式头架,装在一个像眼睛盒一样的盒子里面,同样非常便于携带。这款耳机在头架上有两个垫棉,可以舒服地贴在头顶上,因此戴在头上几乎感觉不到它的存在。PX200高达115DB的灵敏度、仅32欧的阻抗,随便一个随声听都可以将它推的非常好。它的低音非常出色,饱满并且浑厚有力、而且弹性十足,空间感、层次感都非常不错,中高频表现比低音稍差一点。而且这款耳机采用了封闭式的设计,低频能够得到更好的回馈,所以听起来更觉得低频结实有力。

标签: ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Entertainment, Not IT | 4 Comments »

[嗯]OSCache很不错啊

Posted by bianbian on 2006-11-07 19:47


本文Tags: , ,

比较好用,改天再来说一下。
http://www.opensymphony.com/oscache/wiki/JSP%20Tags.html#JSPTags-cache

标签: , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Java, Technology | No Comments »

[哈]收到Meizu M6 MiniPlayer SP了

Posted by bianbian on 2006-11-01 15:05


本文Tags: ,

包装里少了雨伞和抱枕,另外,说好送的魅族PT800耳机变成了微星S60。其他都不错,包装减震也比较到位。
于是和卖家联系,卖家挺实在,淘宝4钻不是盖的,说装包的不是他,可能搞错了。
今天就会把漏送的寄过来,多出来的S60耳机也送我了。总体还不错,我其实是比较满意的(主要是发货快和包装挺实在的)。
推荐一下:http://auction1.taobao.com/auction/0/item_detail-0db1-0c1e354f92f12d2f0d0d90e7707a5dca.jhtml
那样送的东西就变成一个抱枕、一个水晶盒、一个充电器、两个塑胶套、一个PT800、一个微星S80、一把雨伞。
第一次网上买超过1k的东西,还算不错的开端吧。
M6大小大概是一张银行卡的大小,整个比PSP的屏幕稍小一点:
Meizu M6
11月2日补记:东西收到了。这次的包装更坚实。好卖家!以后一定还会去买的。

标签: ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Entertainment, Not IT | 3 Comments »

[原]apache模块的编写实例 (反向透明代理实现方式之一)

Posted by bianbian on 2006-10-30 07:45


本文Tags: , ,

除了用端口映射(当然,要在转发数据包前传递客户端IP地址给内网服务器)来实现反向透明代理以外,利用apache的mod_proxy也是一种办法。而后一种办法更方便的地方是一个80端口可以给很多域名使用(即虚拟主机)——当然前一种也是可以,只要根据不同域名把数据包转发到不同内网服务器而已,我只是懒得写而已;因为工作量显然是直接用apache来得少。。。。
我贴出用后一种办法实现以前lilybbs.net公网代理的代码;之所以要自己写apache的模块,是因为直接用mod_proxy是不能传递客户端的IP地址给真正的内网服务器的。我原本打算是插入自定义的一个HTTP头来实现IP传递,这样一般是没有问题;但是当客户端本身访问网络经过Squid代理时,Squid会删除掉非标准的HTTP头,真是FT。所以我采用的方法是通过”Accept-Language”头传递客户端IP地址,”Accept-Language”是用来标示客户端接受的页面语言顺序(中文?英文?之类),在非国际化的网站中并没有很大的用处。
apache的模块编写其实很简单,大部分都是架子工程,直接贴过来就可以。
代码如下(代码经过lilybbs.net公网访问测试OK,不过现在学校网络中心停止了lilybbs.net的公网出口)。

  1. /*
  2. apache 2.x 模块
  3. 所有http请求的header发送ip,以实现代理
  4. 如需使用 LilybbsipEnable 设为 on 即可(需要和mod_proxy一起使用)
  5.  
  6. 编译:
  7. /home/apache2/bin/apxs -i -a -c mod_lilybbsip.c
  8.  
  9. 参考:
  10. http://modules.apache.org/
  11.  
  12. 作者:
  13. Net@Lilybbs, 2006-3-26 17:38
  14. http://bianbian.org
  15. */
  16.  
  17. #include "httpd.h"
  18. #include "http_config.h"
  19. #include "http_core.h"
  20. #include "http_log.h"
  21. #include "http_protocol.h"
  22. #include "http_vhost.h"
  23. #include "apr_strings.h"
  24.  
  25. module AP_MODULE_DECLARE_DATA lilybbsip_module;
  26.  
  27.  
  28. typedef struct {
  29.     int enable;
  30. } lilybbsip_server_cfg;
  31.  
  32. static void *lilybbsip_create_server_cfg(apr_pool_t *p, server_rec *s) {
  33.     lilybbsip_server_cfg *cfg = (lilybbsip_server_cfg *)apr_pcalloc(p, sizeof(lilybbsip_server_cfg));
  34.     if (!cfg)
  35.         return NULL;
  36.  
  37.     cfg->enable = 0;
  38.  
  39.     return (void *)cfg;
  40. }
  41.  
  42.  
  43. static const char *lilybbsip_enable(cmd_parms *cmd, void *dummy, int flag) {
  44.     lilybbsip_server_cfg *cfg = (lilybbsip_server_cfg *)ap_get_module_config(cmd->server->module_config, &lilybbsip_module);
  45.     cfg->enable = flag;
  46.     return NULL;
  47. }
  48.  
  49. static const command_rec lilybbsip_cmds[] =
  50. {
  51.     AP_INIT_FLAG(
  52.                  "LilybbsipEnable",
  53.                  lilybbsip_enable,
  54.                  NULL,
  55.                  RSRC_CONF,
  56.                  "Enable mod_lilybbsip"
  57.                  ),
  58.     { NULL }
  59. };
  60.  
  61. static int ip_lilybbsing_handler(request_rec *r) {
  62.  
  63.     lilybbsip_server_cfg *cfg = (lilybbsip_server_cfg *)ap_get_module_config(r->server->module_config, &lilybbsip_module);
  64.     if (!cfg->enable)
  65.         return DECLINED;
  66.    
  67.     //通过Accept-Language传递IP
  68.     apr_table_set(r->headers_in, "Accept-Language", r->connection->remote_ip);
  69.  
  70.     return DECLINED;
  71. }
  72.  
  73.  
  74. static void register_hooks(apr_pool_t *p)
  75. {
  76.     ap_hook_post_read_request(ip_lilybbsing_handler, NULL, NULL, APR_HOOK_MIDDLE);
  77. }
  78.  
  79. module AP_MODULE_DECLARE_DATA lilybbsip_module =
  80. {
  81.     STANDARD20_MODULE_STUFF,
  82.     NULL,
  83.     NULL,
  84.     lilybbsip_create_server_cfg,
  85.     NULL,
  86.     lilybbsip_cmds,
  87.     register_hooks,
  88. };

使用的时候在vhost(虚拟主机)内设定:

LilybbsipEnable On
ProxyRequests Off
ProxyPass / http://bbs.nju.edu.cn

标签: , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in C/C++, Linux, Technology | 2 Comments »

[寒]便便游泳回来。。。

Posted by bianbian on 2006-10-28 22:43


本文Tags:

便便游完泳,在路边吃点小吃,所以回家时间不准时了。
噓噓:便便你在哪呢?
便便:我刚吃了点东西,现在走得很快,马上就到了。
噓噓:便便你不要急,慢慢来。
便便:我不急,尿急。
噓噓:噓噓不急
便便:……

标签:

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Not IT, bianbian & xuxu | No Comments »

[原]用PL/pgSQL写postgreSQL的存储过程

Posted by bianbian on 2006-10-27 01:40


本文Tags: , ,

今天学会了用 PL/pgSQL 写 postgreSQL 的存储过程,网上资料实在少得可怜,唯一能搜到的一些还是抄来抄去的;还是翻postgresql的文档吧,把今天解决的问题说一下吧,希望对其他人有帮助。
问题是这样的,有一张message表:
CREATE TABLE message
(
id int8 NOT NULL,
receiveuserid int8,
senduserid int8,
receivedelete bool DEFAULT false,
senddelete bool DEFAULT false,
……
CONSTRAINT usermessage_pkey PRIMARY KEY (id)
)
略去其他字段,senduserid是发信息的用户id,senddelete如为true则表示这条消息被发信人所删除;至于receive我就不用说了。一条信息只有被发信人和收信人都删除,才能真正从表里删除(这是显然的,否则收信人删了一条消息后,发信人的“发件箱”里就会找不到这条消息)。
所以删除消息(可能是多条消息)的时候要进行各种判断(是否是发信人?是否是收信人?是否真正删除?),用单条SQL语句完成这个工作显然有些困难(当然用循环嵌套select不考虑效率的话也是可以实现的),只好写存储过程了。
顺便介绍常用的PL/pgSQL结构和语法吧:

  • 结构
  • PL/pgSQL是一种块结构的语言,比较方便的是用pgAdmin III新建Function,填入一些参数就可以了。基本上是这样的:

    CREATE OR REPLACE FUNCTION 函数名(参数1,[整型 int4, 整型数组 _int4, …])
    RETURNS 返回值类型 AS
    $BODY$
    DECLARE
    变量声明
    BEGIN
    函数体
    END;
    $BODY$
    LANGUAGE ‘plpgsql’ VOLATILE;

  • 变量类型
  • 除了postgresql内置的变量类型外,常用的还有 RECORD ,表示一条记录。

  • 赋值
  • 赋值和Pascal有点像:“变量 := 表达式;”
    有些奇怪的是连接字符串的是“||”,比如 sql := ‘SELECT * FROM’ || table || ‘WHERE …’;

  • 判断
  • 判断又和VB有些像:
    IF 条件 THEN

    ELSEIF 条件 THEN

    ELSE

    END IF;

  • 循环
  • 循环有好几种写法:
    WHILE expression LOOP
    statements
    END LOOP;
    还有常用的一种是:(从1循环到9可以写成FOR i IN 1..9 LOOP)
    FOR name IN [ REVERSE ] expression .. expression LOOP
    statements
    END LOOP;

  • 其他
  • 还有几个常用的函数:
    SELECT INTO record …; 表示将select的结果赋给record变量(RECORD类型)
    PERFORM query; 表示执行query并丢弃结果
    EXECUTE sql; 表示执行sql语句,这条可以动态执行sql语句(特别是由参数传入构造sql语句的时候特别有用)

最后,贴出解决上面这个问题的存储过程吧:

  1. CREATE OR REPLACE FUNCTION message_deletes(ids "varchar", userid int8)
  2.   RETURNS int4 AS
  3. $BODY$
  4. DECLARE
  5.   r RECORD;
  6.   del bool;
  7.   num int4 := 0;
  8.   sql "varchar";
  9. BEGIN
  10.   sql := 'select id,receiveuserid,senduserid,senddelete,receivedelete from message where id in (' || ids || ')';
  11.   FOR r IN EXECUTE sql LOOP
  12.     del := false;
  13.     IF r.receiveuserid=userid and r.senduserid=userid THEN
  14.       del := true;
  15.     ELSEIF r.receiveuserid=userid THEN
  16.       IF r.senddelete=false THEN
  17.         update message set receivedelete=true where id = r.id;
  18.       ELSE
  19.         del := true;
  20.       END IF;
  21.     ELSEIF r.senduserid=userid THEN
  22.       IF r.receivedelete=false THEN
  23.         update message set senddelete=true where id = r.id;
  24.       ELSE
  25.         del := true;
  26.       END IF;
  27.     END IF;
  28.     IF del THEN
  29.       delete from message where id = r.id;
  30.       num := num + 1;
  31.     END IF;
  32.   END LOOP;
  33.   return num;
  34. END;
  35. $BODY$
  36.   LANGUAGE 'plpgsql' VOLATILE;

测试使用:
postgres PL/pgSQL

标签: , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Database, Technology | 1 Comment »

[原]windows命令Copy合并多文件的bug及解决

Posted by bianbian on 2006-10-25 15:03


本文Tags: , , ,

先来看看copy的语法:

C:\Documents and Settings\Administrator>copy /?
将一份或多份文件复制到另一个位置。

COPY [/D] [/V] [/N] [/Y | /-Y] [/Z] [/A | /B ] source [/A | /B]
[+ source [/A | /B] [+ …]] [destination [/A | /B]]

source 指定要复制的文件。
/A 表示一个 ASCII 文本文件。
/B 表示一个二进位文件。
/D 允许解密要创建的目标文件
destination 为新文件指定目录和/或文件名。
/V 验证新文件写入是否正确。
/N 复制带有非 8dot3 名称的文件时,
尽可能使用短文件名。
/Y 不使用确认是否要改写现有目标文件
的提示。
/-Y 使用确认是否要改写现有目标文件
的提示。
/Z 用可重新启动模式复制已联网的文件。

命令行开关 /Y 可以在 COPYCMD 环境变量中预先设定。
这可能会被命令行上的 /-Y 替代。除非 COPY
命令是在一个批文件脚本中执行的,默认值应为
在改写时进行提示。

要附加文件,请为目标指定一个文件,为源指定
数个文件(用通配符或 file1+file2+file3 格式)。

其中,file1+file2+file3还是挺好用的,我一般拿来合并JS脚本,比如:
copy bianbian.main.js + bianbian.DOM.js + bianbian.other.js bianbian.src.js /Y
jsmin <bianbian.src.js >bianbian.js
(用jsmin来删除注释缩进等等,让代码小一点)。

不过,现在发现多文件合并有bug:
1)合并以后在文件末尾会产生一个奇怪的字符(十六进制ASCII码为”1A”),如果直接引用这个js,则任何浏览器都会报错。不过这个字符用jsmin了以后就会被删除,所以这个bug倒并不要紧

2)如果这些文件格式是UTF-8的,合并的时候不会删除每个文件的UTF-8头声明,导致解析出错。我们知道UTF-8格式的文件会用“FF FE”开头(可以看做UTF-8声明),而copy只是简单地将所有文件的ASCII码合并,所以合并后的文件正文也会有“FF FE”。这样,会导致每个源文件第一行的脚本解析出错(比如function,会解析成 ?unction,此处问号表示不认识的字符。不过这个解析目前只在Opera下发现出错)
。解决的办法是每个源文件的第一行都留空,不要写脚本。

标签: , , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Technology, Windows | 1 Comment »

[原]用AutoIt3写了个自动刻盘程序(调用Nero)

Posted by bianbian on 2006-10-23 13:14


本文Tags: , ,

由于我实验室的电脑每小时都要接收一百多兆的卫星数据,刻DVD成了我郁闷不勘的体力活。
前阵子用Delphi写了监听目录,一旦有卫星数据传送完毕,就自动调用RAR压缩,省下几天时间(数据嘛,压缩一下小很多的)。
不过还是挺麻烦,像我这种懒人,最烦体力活了。于是,用AutoIt3写了个自动调用Nero 6 Express刻盘的。原理是:上面说的那个Delphi监听目录程序过一段时间检查数据目录,一旦超过一张盘片的容量了,就调用Nero 6 Express,将目录里所有文件全选进来,然后从底部一个一个删除超过容量的,然后就可以刻录了。刻完以后盘片会弹出来,再将Nero 6关掉,等待下一次刻盘。
唯一的麻烦是虽然自动刻盘了,还得人工去换盘……
我想了几天,没想到什么可行的办法实现自动换盘,现在暂时是刻完一张盘就自动给小师弟发短信,让他来换盘……

标签: , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in AutoIt3, Technology | 8 Comments »

[哈]第一次叠沙拉

Posted by bianbian on 2006-10-22 14:22


本文Tags:

虽然去必胜客几十次了,还是第一次亲手叠沙拉——以前这种细致活都是噓噓的啦。
嘿嘿,好像也还可以。本来想再加几层黄瓜的,噓噓说四个人吃太够了,于是作罢:
pizzahut 叠沙拉

标签:

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in Not IT, bianbian & xuxu | No Comments »

[原] IE在UTF-8下解析JavaScript的bug

Posted by bianbian on 2006-10-20 21:57


本文Tags: , , ,

莫名其妙的脚本问题,脚本肯定没有写错,在IE中就是报错,在Firefox中一切正常:页面是UTF-8的,脚本用了插入页面。
(略去若干抓狂文字。。。。。。)
bianbian.js是ANSI编码的,用记事本保存为UTF-8编码,错误没有了。我觉得是IE的bug:页面是UTF-8编码的,为什么一定要求引用的其他文件也是UTF-8?
下次遇到IE下脚本很奇怪的错误不如看看JavaScript脚本和页面的编码是不是一致。

标签: , , ,

遵守创作共用协议,转载请链接形式注明来自http://bianbian.org 做人要厚道

相关日志

Posted in JavaScript, Technology | No Comments »

Page 12 of 14«1234567891011121314»