Archive for the ‘ 与IT沾边 ’ Category

尚不能饭否,还可来滔滔

饭否 (www.fanfou.com) 至今一直处于被河蟹状态。

   

     “一句话博客”这种东西我觉得很好,有时候有个小灵感想要记录下来,无出存放。

  阅读全文

面向IE7 IE8 HTML 高度自适应解决方案。

    我的客户问我为什么他的网页现在好多内容都缩在一起了。后来了解到是因为他使用了IE8浏览器。这个问题在当时出IE7的时候就已经有了。只是我当时根据后台访问统计来看,使用IE7的人数比例不到2%,我就一直没解决这个问题。现在,看来这个问题越来越严重了。

  阅读全文

晒晒我的米

前几日我代别人注册的一个域名过期了,弄得网站上不去,折腾了好几天才恢复正常。

 

以前域名到期前一个月就会有提醒了。这次居然没收到,后来想想,邮件肯定是发到域名信息里的所有人那去了。我这就没收到。

 

求人不如求己,把我现在收藏的玉米拿出来晒晒,看看保质期过没。顺便也当做摆摊销售了。

  • 9ri.net 10年1月15日过期,已经持有6年(刚好是我的生日那天买的,最好的生日礼物)

  • zhangxu.net 10年2月7日过期,这个是最早我持有的国际域名,02-05年一直持有,后来没有续费被人抢注。09年初我再次抢注过来。

  • easez.com 10年1月18日过期 ,已经持有4年,曾经做过一个资讯类网站,但没做下去。现在已经想把这个域名用作商用网站,转让或者合伙。

  • 4jer.com 10年6月30日过期,已持有1年,是四季宜(E)人的缩写。当时给一家瑜伽网站做网站时候的第二域名方案,后来被否掉。现在一直留着。短小顺口有含义,4也可以理解为英文的four -> for Jer.

 

有需要合作的赶紧骚扰我。

mailto : Chungxu|a|Gmail.com

doname

09清爽版四季伊人网站发布

    过年时候闲下来后,和会所老板沟通了下,决定对网站的页面大改一次。

    这次修改并不另外算费用,为用户第一次设计的版面主要都是我自己的想法,因为用户也没什么想法,只有当网站建起来以后,用户才能根据公司运营和维护的实际情况提出自己的进一步的需求。所以这个版本算是对初版的补充和完善(虽然已经和初版的风更大相径庭)。

    这版设计全部使用最新的DIV+CSS语法,语法规范力求支持更多的浏览器。对flash的使用也谨慎了许多,能用JS取代的都用JS了。大Banner的设计花费了不少时间,当然里面的素材都是网上Down的,source的材质比较清晰,所以效果很棒。可是最后测试的时候,发现不得不把Banner的清晰度降低以获得较好的下载速度。整体的结构基本上是原创的,继承了一些以前我积累的技术,比如文章内容页右侧的晃动导航栏,我很喜欢这个小玩意,所以保留了下来。在配色上显得有些不专业,头部用了浓重的绿色,而网站中、底部颜色有点单调,所以加入了淡色的树叶纹理放在文章列表的下面,但效果一般。可以看出我在网站细节上得布置显得有些经验不足。希望各位童鞋给点建议。

09清爽版四季伊人网站首页

网站链接 : http://www.myyoga365.com

XPS M1330 散热系统改造记

上月末,我的笔记本在安全运行了9个月后,显卡终于体力不支,挂掉了。5月4日,dell工程师上门服务,为我更换了主板。电脑又恢复了正常。我不禁对dell的全面保护和上门维修服务刮目相看。没想到XPS(我的笔记本型号)高端电脑不禁配置高端,服务也高端。

好印象持续了没有半个月。我的显卡又挂掉了。这次故障让我对我这款电脑失望不已。我开始认为戴尔给我更换的是返修过的问题主板。

我打电话报修后,开始查阅关于XPS1330的散热问题的讨论,网友们一致认为这款机型的散热设计有问题。简单说,在显卡的散热面与主风扇散热片之间由于距离过远,使用了比金属导热性低得多的硅胶做导热介质,从而导致散热效果大打折扣。

随后我就把这个问题通过戴尔直通车(戴尔的官方博客),戴尔工程师,本友会论坛XPS售后专版提交了这些问题。但是,反馈的答复最好的就是“我们正在做相关测试”。

看来等官方解决这个问题,那是猴年马月的事儿了,我便决定,在这次电脑修好以后,根据网上网友介绍的方法,自己动手改造我的电脑散热系统。

上周末,我跑到太原青龙数码城,买了两管硅塑。硅塑是一种导热粘稠液体,它用来填充两个接触的导热金属之间微小的缝隙,这些缝隙里充满了空气,大大影响了导热性能。

有了填充物,下面就差金属介质了。导热性能最好的是金、银,但是太贵;其次是铜,但是铜比较重,而且容易生锈;再次就是铝,铝的导热性一般,但是也远高于硅胶(是硅胶的导热系数的50倍左右),很多笔记本的散热材质都采用铜铝合金。

分析完之后,却发现,要找到一块14毫米*14毫米*1.3毫米大小的铜片是很不容易的。有人提议用硬币打磨。最好的是瑞典的5毛硬币,含铜量90%以上,而且大小比较合适,简单打磨光滑之后就可以了。最常见的是旧版5毛人民币,是铜镍合金,含铜量20%左右。导热性要差很多。但是这是最好搞到的材料。

从电脑城回来的路上又买了三角锉,砂纸。一切齐备。

改造的最难得部分就是打磨,要把5毛钱的花纹磨平,花了我1个多小时。将打磨好的铜片放上,涂上硅塑,接上风扇电源,开机反复测试,结果并不理想。

散热效果几乎和改造前没什么区别。和网上的说法有很大差异。经过对比,发现有三个原因,首先是我打磨的工艺比较粗糙,硬币可能不够平整,而且好像厚度小于1.3毫米,导致接触不是很充分;第二是我是用的介质为5毛硬币,含铜量比较低,散热效果可能不理想;第三是我的硅塑是两块钱一管的便宜货,网上的达人用的都是100多块钱的黄金导热硅脂(纯金属含量)。

就此,我改造电脑的计划,告一段落。首先工作要紧,万一改造电脑造成硬件损坏那就耽误工作了,然后是考虑条件不足,待材料满足后再改不迟。这段时间,就少玩大型3D游戏为妙。

经过这次动手实践,至少证明了一点,这么改,至少不会让电脑散热更坏,也就说如果材料改进后,改良散热还是有希望的。

PS:全世界求购 14毫米*14毫米*1.3-2.0毫米的金、银、铜、铝片

有意者可以Mail我 zhangxu(at)asiainfo.com

[TCL]取时间、格式化时间

clock seconds 取一个整型值

用命令可以格式化时间

clock format  时间变量 -format 参数

参数可以为:

%% Insert a %.
%a Abbreviated weekday name (Mon, Tue, etc.).
%A Full weekday name (Monday, Tuesday, etc.).
%b Abbreviated month name (Jan, Feb, etc.).
%B Full month name.
%c Locale specific date and time.
%d Day of month (01 – 31).
%H Hour in 24-hour format (00 – 23).
%I Hour in 12-hour format (00 – 12).
%j Day of year (001 – 366).
%m Month number (01 – 12).
%M Minute (00 – 59).
%p AM/PM indicator.
%S Seconds (00 – 59).
%U Week of year (01 – 52), Sunday is the first day of the week.
%w Weekday number (Sunday = 0).
%W Week of year (01 – 52), Monday is the first day of the week.
%x Locale specific date format.
%X Locale specific time format.
%y Year without century (00 – 99).
%Y Year with century (e.g. 1990)

%D Date as %m/%d/%y.
%e Day of month (1 – 31), no leading zeros.
%h Abbreviated month name.
%n Insert a newline.
%r Time as %I:%M:%S %p.
%R Time as %H:%M.
%t Insert a tab.
%T Time as %H:%M:%S.

举例

when CLIENT_ACCEPTED {
 set curtime [clock seconds]
 log local0.warning “当前时间$curtime”
 set formattime [clock format $curtime -format {%D %T}]
 log local0.warning “格式时间$formattime”
}

curtime表现如下:

15:31  192.168.162.254  warnings  tmm tmm[1045]: Rule test_length: 当前时间1206689510 

%D %T表现如下

15:31  192.168.162.254  warnings  tmm tmm[1045]: Rule test_length: 格式时间03/28/08 15:31:50 

when CLIENT_ACCEPTED {
 set curtime [clock seconds]
 log local0.warning “当前时间$curtime”
 set formattime [clock format $curtime -format %m]
 set lin [expr $formattime+1]
 log local0.warning “格式时间$formattime ..$lin”
}

上面这个输入如下

15:37  192.168.162.254  warnings  tmm tmm[1045]: Rule test_length: 格式时间03 ..4 

取出日期中的值,作为变量使用。在需要的时候可以发挥作用

二叉树的好处

碰到一个题目:做一个通讯录,使用ORACLE数据库,C++,二叉树存储结构,包含索引文件。

花了两天时间,把oracle和C++接口函数OCI搞定。开始考虑程序的设计。

分层考虑:

数据库层,使用C++OCI接口完成。

传输层,使用二叉树存储传递。

应用层,简单窗口化界面。

我出现了一个疑问,为什么要用二叉树,为什么不使用链表。问了辅导老师,他也有类似的疑问–“链表删除和插入的性能更加优秀”。

花了点时间做了点功课。找到了答案:

  二叉排序树是一种比较有用的折衷方案。  
  数组的搜索比较方便,可以直接用下标,但删除或者插入某些元素就比较麻烦。  
  链表与之相反,删除和插入元素很快,但查找很慢。  
  二叉排序树就既有链表的好处,也有数组的好处。  
  在处理大批量的动态的数据是比较有用。

PS:google在查IT技术问题的结果要远远好于baidu。

用STL快速编写ini配置文件识别类

ini文件是技术人员经常用到的一种系统配置方法,如何读取和快速识别ini文件中的内容实现起来比较繁琐。STL强大的功能在于能快速的实现排序、查找、 识别等功能。本文通过STL中的map,string,vector,ifstream等,来快速实现ini文件的识别类class IniFile?。IniFile可以实现常见查找功能,并提供完整的源码。

1 设计需求:
ini文件的格式一般如下:

[section1]
key1=value1
key2=value2
……

[section2]
key1=value1
key2=value2 #注释
……

实际的例子是:

#ini for path
[path]
dictfile = /home/tmp/dict.dat
inputfile= /home/tmp/input.txt
outputfile= /home/tmp/output.txt

#ini for exe
[exe]
user= winter //user name
passwd= 1234567 #pass word
database= mydatabase

其中有五种元素:section 名,Key名,value值,注释 #或者//开头,标志字符”[" "]” “=”。查找项的对应关系为sectiong-key和value对应。需要得到是value。class IniFile?要实现的是两个函数:读入ini文件,读取sect-key对应的value值。即实现下面的接口:

class IniFile{
public:
  IniFile();
  //打开ini文件
  bool open(const char* pinipath);
  //读取value值
  const char* read(const char* psect, const char*pkey);
  };

2 设计实现:
用ifstream按行读入ini文件的内容

识别每一行的字符串,分析出sectiong,key,value,和注释。

用map来记录所有的sectiong-key和value。

重新定义class IniFile?

typedef map<string, string, less<string> > strMap;
typedef strMap::iterator strMapIt;

const char*const MIDDLESTRING = “_____***_______”;
class IniFile
{
public:
  IniFile( ){};
  ~IniFile( ){};
  bool open(const char* pinipath)
  {
  return do_open(pinipath);
  }
  string read(const char*psect, const char*pkey)
  {
  string mapkey = psect;
  mapkey += MIDDLESTRING;
  mapkey += pkey;
  strMapIt it = c_inimap.find(mapkey);
  if(it == c_inimap.end())
  return “”;
  else
  return it->second;
  }
protected:
  bool do_open(const char* pinipath)
  {
  ifstream fin(pinipath);
  if(!fin.is_open())
  return false;
  vector<string> strvect;
  while(!fin.eof())
  {
  string inbuf;
  getline(fin, inbuf,’\n’);
  strvect.push_back(inbuf);
  }
  if(strvect.empty())
  return false;
  for_each(strvect.begin(), strvect.end(), analyzeini(c_inimap));
  return !c_inimap.empty();
  }
  strMap c_inimap;
};

其中do_open是用来真正实现初始化ini内容的函数。先用ifstream fin打开一个文件,然后用is_open判断文件是否正常打开。顺序读取文件的时候用eof()判断是否到文件尾。getline是一个字符处理函数:直接从fin中读取一行。然后用while循环过滤一行末尾的空格等字符。最后保存到一个vector中,完成读入文本工作。其中比较值得关注的是以下为体,你知道为什么这么做么?用ifstream和getline来读入而不是用fopen和fread。
用is_open判断是否打开,而不是直接读取。
用vector的push_pack而不是insert。
用empty判断是否为空,而不是用size()==0。
下一步用for_each函数来完成字符串的内容提取工作。声明一个结构,实现对操作符()的重载。代码如下:

struct analyzeini{
  string strsect;
  strMap *pmap;
  analyzeini(strMap & strmap):pmap(&strmap){}
  void operator()( const string & strini)
  {
  int first =strini.find(‘[');
  int last = strini.rfind(']‘);
  if( first != string::npos && last != string::npos && first != last+1)
  {
  strsect = strini.substr(first+1,last-first-1);
  return ;
  }
  if(strsect.empty())
  return ;
  if((first=strini.find(‘=’))== string::npos)
  return ;
  string strtmp1= strini.substr(0,first);
  string strtmp2=strini.substr(first+1, string::npos);
  first= strtmp1.find_first_not_of(” \t”);
  last = strtmp1.find_last_not_of(” \t”);
  if(first == string::npos || last == string::npos)
  return ;
  string strkey = strtmp1.substr(first, last-first+1);
  first = strtmp2.find_first_not_of(” \t”);
  if(((last = strtmp2.find(“\t#”, first )) != string::npos) ||
  ((last = strtmp2.find(” #”, first )) != string::npos) ||
  ((last = strtmp2.find(“\t//”, first )) != string::npos)||
  ((last = strtmp2.find(” //”, first )) != string::npos))
  {
  strtmp2 = strtmp2.substr(0, last-first);
  }
  last = strtmp2.find_last_not_of(” \t”);
  if(first == string::npos || last == string::npos)
  return ;
  string value = strtmp2.substr(first, last-first+1);
  string mapkey = strsect + MIDDLESTRING;
  mapkey += strkey;
  (*pmap)[mapkey]=value;
  return ;
  }
};

这里大量使用了字符串的查找和字串功能。string的find_last_of系列和find系列,功能确实十分强大。所有在string中没有找到都会返回一个变量string::npos。
函数先找sectiong,然后分离key值和value值。符合要求的,把section和key值通过中间加上MIDDLESTRING组成一个新的string,插入map中。这里值得注意的是:

* for_each的使用,结构可以传递参数。 * string的查找函数及返回值 * string的链接和合并函数。 * map的下标操作符的使用。

3 具体使用
把所有代码放在一个头文件中,以后别人使用的时候,只需要包含头文件就可以了,点击查看inifile.h文件。在使用的过程中,注意判断返回值。使用代码如下:

#include <iostream>
#include “inifile.h”
using namespace std;
int main()
{
    IniFile ini;
    if(!ini.open(“test.ini”))
       return -1;
    string strvalue = ini.read(“sect1″,”key1″);
    if(strvalue.empty())
        return -1;
    else
        cout<<”value=”<<strvalue<<endl;
    return 0;
}  

——————————————————————————–

Set MYTITLE = 用STL快速编写ini配置文件识别类

FTP server 制作总结

张旭 2008-1-8

需求

实现LSPUTGETCLOSE命令。

实现多用户并发访问添加配置文件,可以设置端口、主目录及虚拟目录、最大同时访问数、访问日志参照 socket++ 开源项目,用面向对象的方法实现不能同时上传同名文件,上传中的文件不能被下载配置为 Linux 服务,能自动运行支持命令行方式启动服务:start为启动服务、stop为停止服务捕捉全部 FTP 动作,实时显示

知识准备

文件读写操作

目录操作

C++面向对象知识

SOCKET编程:了解不同程序间收发信息的方法,sendresv,了解阻塞。

FTP协议-RFC959 :了解FTP报文书写原则和相关规定。

FTP通信过程 :使用网络通信捕捉工具,观察通信过程。

多线程: 父进程和子进程关系,僵尸进程。

信号:了解各种信号的产生和处理。

进程间通信:共享内存,信号量,消息队列,管道。文件锁。

守护进程

Linux服务配置:etc/init.d目录

系统日志添加方法

程序制作周期

071260818

开发进度(粗体表示难点)

126熟悉FTP协议RFC959,配置linux ftp服务。

127,利用科来网络分析系统,观察ftp传输过程。

128,实现简单ftp服务端,可根据不同的请求给出相应答复。多线程知识准备。

129,研究ftp主动、被动传输模式。尝试获取传递信息中的关键信息。

1210,研究ftp被动传输模式。研究本机ip地址的获取方法。实现LIST命令的接收和回应。解决端口无法短时间内多次被绑定问题。

1211,完成整个ftp传输过程的观测,画出整个工作流程图。

1212,实现socket类。实现FTP类。

1213,将两个类实例化,实现面向对象ftp基本程序。实现多线程,可以多人同时访问。

1215实现GET命令PUT命令

1216,实现ftp的全部基本功能,LISTPUTGETCLOSE

1217-1223进程间通信的学习,英语四级考试准备。

1224-25日,信号量操作的学习,实现PV操作

1226,共享内存的学习,实现PV类。

1227,利用PV类实现同时在线人数的控制,学习守护进程相关知识

1228,僵尸进程问题的学习。

1229-30日,信号及其通信学习。实现配置文件,实现文件锁功能。

1230实现利用进程间通信控制守护进程的运行

11,完善FTP服务器及相关子类。增加超时断开连接功能

12,配置linux服务,设置为开机自动运行程序

13-7日,期末考试,完善全部功能细节。

18,编写文档和总结。

文件结构

config.txt

配置文件,被main.cpp调用。

FTPS.cpp

FTPS类,被main.cpp调用

FTPS.h

FTPS类头文件,被FTPS.h 调用。

main.cpp

主程序文件,参数: start 开始 stop 停止。守护进程

mk

编译shell指令。

PV.cpp

PV操作类,被FTPS.cpp调用。

PV.h

PV操作类头文件,被PV.cpp调用。

seeMessage.cpp

FTP监控程序,输入FTP安装路径,即可开始监控。

SOCKET.cpp

套接口类,被FTP.cpp调用。

SOCKET.h

套接口类头文件,SOCKET.cpp调用。

本程序安装配置方法

1.   1. 将以上10个文件拷贝到要安装的目录下,假设为 /prefix/

2.     使用任意文本编译器打开config.txt文件,设置ftp_port端口号),main_pathFTP默认上传目录),install_path  = /prefix/online_number(最大支持同时在线人数),logfile_path(日志存放地址)。

3.     配置完毕以后,在终端输入 sh /prefix/mk 编译文件,生成main程序执行文件。

4.     运行程序:./prefix/main start5.     结束程序:./prefix/main stop

stat.h头文件,轻松获取文件属性。

【以前还为了获取文件的长度,费劲从头读取一遍,一个一个字节的算。
做webserver时候,发现原来stat函数可以返回一个结构,里面包括文件的全部属性。
真是曲折啊。】

#i nclude<sys/stat.h>
int stat(const char *restrict pathname,struct stat *restrict buf);
int fstat(int fields,struct stat *buf);
int lstat(const char *restrict pathname,struct stat *restrict buf);

 返回值:若成功则返回0,失败则返回-1
 
 一旦给出pathname,stat函数就返回与此命名文件有关的信息结构,fstat函数获取已在描述符fields上打开文件的有关信息。
 lstat函数类似于stat.但是当命名的文件是一个符号链接时,lstat返回该符号链接的有关信息,而不是由该符号链接引用文件
 的信息。第二个参数buf是指针,它指向一个我们必须提供的结构,这些函数填写由buf指向的结构。该结构的实际定义可能随实现
 有所不同.
   struct stat{
mode_t st_mode; //文件类型和权限信息
ino_t st_ino; //i结点标识
dev_t st_dev; //device number (file system)
dev_t st_rdev; //device number for special files
nlink_t st_nlink; //符号链接数
uid_t st_uid; //用户ID
gid_t st_gid; //组ID
off_t st_size; //size in bytes,for regular files
time_t st_st_atime; //最后一次访问的时间
time_t st_mtime; //文件内容最后一次被更改的时间
time_t st_ctime; //文件结构最后一次被更改的时间
blksize_t st_blksize; //best I/O block size
blkcnt_t st_blocks; //number of disk blocks allocated
};

文件类型:
  普通文件,目录文件,块特殊文件,字符特殊文件,套接字,FIFO,符号链接.
  文件类型信息包含在stat结构的st_mode成员中,可以用如下的宏确定文件类型,这些宏是stat结构中的st_mode成员.
  S_ISREG();S_ISDIR();S_ISCHR();S_ISBLK();S_ISFIFO();S_ISLNK();S_ISSOCK()
 
  示例:
     #i nclude<iostream>
     int main(int argc,char* argv[])
     {
          int i;
        struct stat buf;
        char * ptr;
        
        for(i=1;i<argc;i++)
         {
            if(lstat(argv[i],&buf)<0)
               {
                 perror(“错误原因是:”);
                 continue;
               }

            if (S_ISREG(buf.st_mode))
                ptr=”普通文件”;
            if (S_ISDIR(buf.st_mode))
                ptr=”目录”;
            
            //……and so on…
            
           cout<<”参数为:”<<argv[i]<<”的标识是一个”<<ptr<<endl;
         }
        exit(0);
     }
 
  <!–
  POSIX.1(Portable Operation System Interface)是一组操作系统规范,符合这个规范的操作系统之间行为一致,而且系统调用一致。  
  Unix是AT&T的注册商标,其他厂商必须付费才可以使用,Solaris是SUN公司的UNIX系统,因为版权问题不能叫Unix
  Linux是GNU的操作系统项目,是 一个类Unix操作系统。
  –>
  POSIX.1允许实现将进程间通信(IPC)对象(如:消息队列和信号量等)表示为文件.以下宏可以用来确定IPC对象的类型.以下宏与S_ISREG等宏不同,
  它们的参数并非st_mode,而是指向stat结构的指针.
  如:S_TYPEISMQ()表示消息队列; S_TYPEISSEM()表示信号量 ; S_TYPEISSHM()表示共享存储对象.
 
  进程每次打开,创建或删除一个文件时,内核就进行文件访问权限测试,而这种测试可能涉及文件的所有者(st_uid和st_gid),进程的有效ID(有效用户ID或有效组ID)以及进程的附加组ID,两个所有者ID是文件的性质,而两个有效ID和附加组ID则是进程的性质,内核进行的测试是:
  (1).若进程的有效用户ID是0(超级用户),则允许访问。
  (2).若进程的有效用户ID等于文件的有效用户ID,那么若所在者适当的访问权限被设置,则允许访问。
  (3).若进程的有效组ID或进程的附加组ID之一等于文件的组ID,那么组适当的访问权限位被设置,则允许访问。
  (4).若其他用户适当的访问权限位被设置,则允许访问。
 按顺序执行以上四步。

 

无觅相关文章插件,快速提升流量