Rexdf

The devil is in the Details.

[置顶]发布一个sublime汉化插件

| Comments

很简单的一个插件,现在支持汉化Sublime Text2,Sublime Text3。全部系统Win64、Win32,Linux64,Linux32,OSX等,可以随意来回切换简体中文、繁体中文、日语、英语,无需重启SublimeText。

Octopress代码高亮

| Comments

语法高亮

语法

``` [language] [title] [url] [link text] [linenos:false] [start:#] [mark:#,#-#]
code snippet
```

说明

 [language] - Used by the syntax highlighter. Passing 'plain' disables highlighting.
 [title] - Add a figcaption to your code block.
 [url] - Download or reference link for your code.
 [Link text] - Text for the link, defaults to 'link'.

例子1

``` ruby Discover if a number is prime http://www.noulakaz.net/weblog/2007/03/18/a-regular-expression-to-check-for-prime-numbers/ Source Article
 class Fixnum
   def prime?
     ('1' * self) !~ /^1?$|^(11+?)\1+$/
   end
 end
```

显示成

Discover if a number is primeMyBlog
class Fixnum
def prime?
('1' * self) !~ /^1?$|^(11+?)\1+$/
end
end

例子2.

``` matlab MathJax Example http://blog.rexdf.org MyBlog
\begin{align*}
  & \phi(x,y) = \phi \left(\sum_{i=1}^n x_ie_i, \sum_{j=1}^n y_je_j \right)
  = \sum_{i=1}^n \sum_{j=1}^n x_i y_j \phi(e_i, e_j) = \\
  & (x_1, \ldots, x_n) \left( \begin{array}{ccc}
      \phi(e_1, e_1) & \cdots & \phi(e_1, e_n) \\
      \vdots & \ddots & \vdots \\
      \phi(e_n, e_1) & \cdots & \phi(e_n, e_n)
    \end{array} \right)
  \left( \begin{array}{c}
      y_1 \\
      \vdots \\
      y_n
    \end{array} \right)
\end{align*}
```

则为

MathJax ExampleMyBlog
\begin{align*}
& \phi(x,y) = \phi \left(\sum_{i=1}^n x_ie_i, \sum_{j=1}^n y_je_j \right)
= \sum_{i=1}^n \sum_{j=1}^n x_i y_j \phi(e_i, e_j) = \\
& (x_1, \ldots, x_n) \left( \begin{array}{ccc}
\phi(e_1, e_1) & \cdots & \phi(e_1, e_n) \\
\vdots & \ddots & \vdots \\
\phi(e_n, e_1) & \cdots & \phi(e_n, e_n)
\end{array} \right)
\left( \begin{array}{c}
y_1 \\
\vdots \\
y_n
\end{array} \right)
\end{align*}

例子3

这个

{ % jsfiddle 3h5A4/3 %}

神奇一些(说明markdown的bug,所以我在{和%之间加了空格,应该去掉)

例子4

这个也是

{ % gist 2436351 %}

显示为

例子5

更加神奇的

{ % gist 996818 %}

显示为

Octopress Is Great

| Comments

Octopress还是很不错的

刚刚发现了用MarkdownPad写日志,一般预览,而如果开着rake preview则可以实时生成. 插入图片

推荐一个有前途的开源软件–OpenSearchServer

| Comments

主页在这里,看页面右边那个Youtube的视频就知道怎么回事了,我就是用了视频中提到的功能,但是发现对于中文支持非常地差,但是英文单词效果似乎很好。如果将来发展似乎还是很有前途的,自主的全文搜索,还是一件很不错的事情。 [caption id=”attachment_1960” align=”alignnone” width=”903”]OpenSearchServer 很不错的开源搜索引擎软件[/caption]

Movabletype安装

| Comments

大名鼎鼎的Movable Type(简称MT),曾经风靡一时,后来因为种种原因被Wordpress赶超,虽然当初勉为其难地开源又转为收费,其中的折腾自是不用多说,但是在很多人心中依然认为只有MT才算是真正的博客系统,写作发布,静态化的博客速度简直不是一般的快。 我首先是发现Openshift可以支持Perl,于是想安装MT试试,采用了github源git直接安装,结果Openshift发现里面有一个makefile还是怎么的,上传上去后一直编译中,开始不懂以为perl是要编译的,后来才知道其实他是在检测依赖关系,把出现过的脚本全部依赖库都检测一遍,然后最后就出现了Error,好像一直是在Oracle DB的链接库上,这是显然的。搜索解决方案中惊讶的发现Openshift上面可以编译程序,居然可以ssh进去之后wget一个per16.3.1.tar的源码然后解压编译一个自己的源码,可以参考这里,我在想Openshift是不是可以做一个OJ了,居然支持编译,简直就是VPS啊!! Google里面似乎没有人说直接在上面成功搭建过MT,但是有人尝试失败过,我经过一些尝试最后发现了只要在.openshift/marker/下面touch一个hot_deploy就不会重新编译了,而且git push之后的代码结构是不会变的。这样就可以相当于ftp上传的效果了(发现如果支持git,那么git比ftp一般快不止一个数量级,具体原因还有待分析),另外还有一些参数enable_cpan_tests, force_clean_build等switch可以设置。参考这里,在document里面有,但是现在是404错误,不知道是不是github的问题(CNAME需要设置子目录吗?)。 接着继续讲Openshift上的安装,无意中在一次hot_deploy的情况下,我进去了安装界面,然后非常意外的,点击下一步下一步,最后进入了博客系统,还发布了一遍表示兴奋的“文章,于是立马绑上了一个域名,然后就问题也出现了,发现再次写一遍的时候不停的Gateway Time Out,起初我还能忍受,后来发现简直点一下鼠标出现一次,需要不停刷新,于是乱掉了,重复发了那么多文章我都不知道,然后发布,居然也成功了,不过今天进去再次写一点发布的时候就一直Gateway Time Out了,没办法,放弃吧。想到是静态化的,何不本地生成,网络发布,于是Win8下试着安装,我不想用Stawberry Perl或者ActivePerl,虽然这两个以前一直安装,但是自从发现Cygwin最近常更新之后就再也不用那两个了。这样包需要自己安装首先

perl -MCPAN -e "shell"

在没有安装CPAN的时候shell是需要加引号的,安装好之后就无所谓了,这里有一个trick的地方是要选no,不要自动配置

Would you like to configure as much as possible automatically? [yes]

选了no之后就有一系列的配置,这里需要自己手动安装同时打开Cygwin的包安装器setup-x86.exe(或者setup-x86_64.exe),发现提示什么没有就安装什么,目录是在cygwin/bin,推荐把所有的执行程序都改成/bin/xx.exe就可以了,当然exe省掉是可以的,而且更有Linux的味道。这样就把Per的CPAN安装好了,再次执行

perl -MCPAN -e "shell"

进入

cpan shell -- CPAN exploration and modules installation (v2.00)
Enter 'h' for help.

cpan[1]> 

这时就可以安装CPAN里面的包了,一个推荐的安装是

notest install Dancer Mojolicious DBD::Pg DBD::SQLite DBD::mysql DBI Image::Size CGI::Cookie IPC::Run Authen::SASL Cache::Memcached Cache::File Crypt::SSLeay GD Crypt::DSA XML::Parser Digest::SHA1 Plack Imager XML::Atom XMLRPC::Transport::HTTP::Plack Net::SMTP::SSL DBD::SQLite2 Cache::File CGI::PSGI GD CGI::Parse::PSGI Image::Magick Imager DBD::Pg HTML::Template

执行完了quit退出。需要说明的是需要先在Cygwin里面安装好GD和Image Magick等包,还有就是Cygwin的各个c/c++编译包是要的,在devel目录下面好像是有三套不同的开发包的,分别针对MingW和Cygwin以及gnu gcc本身的,一般我都是全部安装(指这三套,不是所有语言比如fortan我就百分百不会安装)。 接下去就是配置cgi-bin目录问题了,这里不能用cgi-bin专用目录,因为ScriptAlias /cgi-bin/ “D:/Users/Rexdf/php/Web/cgi-bin/”这样做的就是CGI目录,会把其下面全部文件都当做cgi程序执行,这样的话一个html文件也会被当做脚本执行,然后提示500服务器内部错误,解决办法是把这一行注释掉,然后让它成为普通目录,配置下面的语句,可以在vhosts.conf里面,也可以在httpd.conf里面

<Directory "D:/Users/Rexdf/php/Web/cgi-bin">
    AllowOverride All 
    Options +ExecCGI
    AddHandler cgi-script .cgi .pl
    Allow from all
    Order allow,deny 
</Directory>

这里关键的即使Options +ExecCGI了,同时也要在AddType application/x-httpd-php .php这一行上面一些地方添加AddHandler cgi-script .cgi .pl,这样就可以了。 接下去就是Cygwin里面的perl如何连接数据库的问题了,自然最好的选择是Mysql(好像可以支持SQLite,但是我没配置成功),Cygwin的包里面有Mysql的Server也有Mysql的Client,我们需要的只有Client,因为我系统已经安装了最新5.6.12而且正打算升级到5.6.14,不必使用Cygwin里面的5.5.31什么的。一般会遇到如下的错误: Error: Can’t connect to local MySQL server through socket ‘/var/run/mysql.sock’ 需要做的就是配置Mysql Client,把D:\Users\rexdf\cygwin\usr\share\mysql里面的my-huge.cnf复制到D:\Users\rexdf\cygwin\etc\my.cnf,可以用如下命令

cp /usr/share/mysql/my-huge.cnf /etc/my.cnf

同时编辑其中内容,在client最后添加一行protocol = TCP。然后做如下的两个测试 1.命令行测试

mysql -h 127.0.0.1 -P 3306 -u root -P

输入密码如果进入数据库并显示5.6.12数据库的欢迎信息,那么就client是OK的了。 2.Perl的DBD::msqyl测试 脚本如下

#!bin/perl
use DBI;
my $dbname = "movabletype_db";#这个数据库现在phpMyAdmin里面建立好
my $location = "127.0.0.1";
my $port = "3306"; #这是mysql的缺省
my $database = "DBI:mysql:$dbname:$location:$port";
my $db_user = "root";
my $db_pass = "您的密码";
my $dbh = DBI->connect($database,$db_user,$db_pass);
my $sql = "SELECT first_name,last_name FROM $table ORDER BY first_name";
my $sth = $dbh->prepare($sql);
$sth->execute() or die "无法执行SQL语句:$dbh->errstr"; 
$dbh->disconnect;#断开数据库连接

如果看到的是无法执行SQL,而不是Error: Can’t connect to local MySQL server through socket ‘/var/run/mysql.sock’,那么恭喜你成功了,可以进入下一步的正式安装了,先下载

git clone https://github.com/movabletype/movabletype.git

吐槽下QQ邮箱

| Comments

discuz后台的smtp设置是不支持ssl加密连接的,然后就发现QQ企业邮箱似乎默默地取消了新增的25端口支持,而且做的挺有意思。为了安全使用的@bbs.rexdf.org的随机密码做smtp服务器,但是昨天重装的时候密码丢了,然后进去改了,结果发现discuz测试不通过,然后跑去找官方文档,结果怎么也找不到不用ssl的25端口的说明了。现在似乎是疼逊自己做的什么信件模板加465端口,貌似需要重写代码了。不知道对于模板邮件是不是限制少一些。有意思的是,我博客的后台使用的却依然在工作,而且在25端口上,虽然博客的那个插件本身支持ssl的,我也不敢尝试登陆那个邮箱账号了,应该是疼逊采用的逐步推广的方式。

0x80070043错误,在非SSL情况下链接WebDav

| Comments

这应该是个经典的错误,在Windows官网都是有解决方案的。问题的关键是两点:①开启service.msc中的WebClient;②注册表HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\WebClient\Parameters下面有一个DWORD的BasicAuthLevel键,其值含义0 - 禁用基本身份验证;1 - 只启用 SSL 连接的基本身份验证;2 - 启用 SSL 连接和非 SSL 连接的基本身份验证;所以我们改成2就OK了,改完需要重启。 附一个步骤图:说明 参看网址: 1. http://support.microsoft.com/kb/2123563 2. http://www.scotttyee.com/blog/2011/07/24/mapping-a-network-drive-to-webdav-share-in-windows-7/

360doc如何复制

| Comments

这只是一个很简单的tips,IE10,Firefox,Chrome中均可以,Opera和Safari我不想启动,按下F12启动开发者工具,然后点击Console,进入控制台,输入

document.body.oncopy=""

然后按下回车,再复制就没问题了。 360doc上面自己说的是按住拖动到Word(保留格式)或者记事本。 网上还有说另存为的。 应该都是方法。

临时禁止MathJax的方法

| Comments

MathJax可以很好地在网页进行数学公式的嵌入,质量很高。如需要嵌入,只需要加入

<script type="text/javascript" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=default"></script>

即可以在任何想用的使用使用了。行间公式是$$之间,行内公式是\\(\\),但是上篇正则表达式里面就有大量的这样符号,会被MathJax替换成数学公式,解决的办法是加一个标签包住即可。

Comments

rexdf: :wenti: :shengbing: :shangxinku:

rexdf: #include using namespace std; int main() { cout << “HellO”<<endl; return 0; }

rexdf: \(x^21+x^22=25\)是一个二元二次方程. When $a \ne 0$, there are two solutions to \(ax^2 + bx + c = 0\) and they are

rexdf: :keai2:

Vim 正则表达式[转]

| Comments

毋庸多言,在vim中正则表达式得到了十分广泛的应用。 最常用的 / 和 :s 命令中,正则表达式都是不可或缺的。 下面对vim中的正则表达式的一些难点进行说明。

1.关于magic

vim中有个magic的设定。设定方法为: :set magic “ 设置magic :set nomagic “ 取消magic :h magic “ 查看帮助 vim毕竟是个编辑器,正则表达式中包含的大量元字符如果原封不动地引用(像perl 那样), 势必会给不懂正则表达式的人造成麻烦,比如 /foo(1) 命令, 大多数人都用它来查找foo(1)这个字符串, 但如果按照正则表达式来解释,被查找的对象就成了 foo1 了。 于是,vim就规定,正则表达式的元字符必须用反斜杠进行转义才行, 如上面的例子,如果确实要用正则表达式,就应当写成/foo\\(1\\)。 但是,像 . * 这种极其常用的元字符,都加上反斜杠就太麻烦了。 而且,众口难调,有些人喜欢用正则表达式,有些人不喜欢用…… 为了解决这个问题,vim设置了 magic 这个东西。简单地说, magic就是设置哪些元字符要加反斜杠哪些不用加的。 简单来说: magic (\m):除了 $ . * ^ 之外其他元字符都要加反斜杠。nomagic (\M):除了 $ ^ 之外其他元字符都要加反斜杠。 这个设置也可以在正则表达式中通过 \m \M 开关临时切换。 \m 后面的正则表达式会按照 magic 处理,\M 后面的正则表达式按照 nomagic 处理, 而忽略实际的magic设置。 例如: /\m.* # 查找任意字符串 /\M.* # 查找字符串 .* (点号后面跟个星号) 另外还有更强大的 \v 和 \V。 \v (即 very magic 之意):任何元字符都不用加反斜杠\V (即 very nomagic 之意):任何元字符都必须加反斜杠 例如: /\v(a.c){3}$ # 查找行尾的abcaccadc /\m(a.c){3}$ # 查找行尾的(abc){3} /\M(a.c){3}$ # 查找行尾的(a.c){3} /\V(a.c){3}$ # 查找任意位置的(a.c){3}$ 默认设置是 magic,vim也推荐大家都使用magic的设置,在有特殊需要时,直接通过 \v\m\M\V 即可。 本文下面使用的元字符都是 magic 模式下的。

2.量词

vim的量词与perl相比一点也不逊色。

vim Perl 意义

* * 0个或多个(匹配优先)

\+ + 1个或多个(匹配优先)

\? 或 = ? 0个或1个(匹配优先),\?不能在 ? 命令(逆向查找)中使用

\{n,m} {n,m} n个到m个(匹配优先)

\{n,} {n,} 最少n个(匹配优先)

\{,m} {,m} 最多m个(匹配优先)

\{n} {n} 恰好n个

\{-n,m} {n,m}? n个到m个(忽略优先)

\{-} *? 0个或多个(忽略优先)

\{-1,} +? 1个或多个(忽略优先)

\{-,1} ?? 0个或1个(忽略优先)

从上表中可见,vim的忽略优先量词不像perl的 *? +? ?? 那样,而是统一使用 \{- 实现的。 这大概跟忽略优先量词不常用有关吧。

3.环视和固化分组

vim居然还支持环视和固化分组的功能,强大,赞一个  关于环视的解释请参考Yurii的《精通正则表达式》 一书吧。

vim Perl 意义

\@= (?= 顺序环视

\@! (?! 顺序否定环视

\@<= (?<= 逆序环视

\@<! (?<! 逆序否定环视

\@> (?> 固化分组

\%(atom\) (?: 非捕获型括号

和perl稍有不同的是,vim中的环视和固化分组的模式的位置与perl不同。 例如,查找紧跟在 foo 之后的 bar,perl将模式写在环视的括号内, 而vim将模式写在环视的元字符之前。 # Perl的写法 /(?<=foo)bar/ # vim的写法/\\(foo\\)\@<=barvim正则表达式 写道

4.元字符 说明

. 匹配任意一个字符 [abc] 匹配方括号中的任意一个字符。可以使用-表示字符范围, 如[a-z0-9]匹配小写字母和阿拉伯数字。 [^abc] 在方括号内开头使用^符号,表示匹配除方括号中字符之外的任意字符。 \d 匹配阿拉伯数字,等同于[0-9]。 \D 匹配阿拉伯数字之外的任意字符,等同于[^0-9]。 \x 匹配十六进制数字,等同于[0-9A-Fa-f]。 \X 匹配十六进制数字,等同于[^0-9A-Fa-f]。 \w 匹配单词字母,等同于[0-9A-Za-z]。 \W 匹配单词字母之外的任意字符,等同于[^0-9A-Za-z_]。 \t 匹配字符。 \s 匹配空白字符,等同于[ \t]。 \S 匹配非空白字符,等同于[^ \t]。 \a 所有的字母字符. 等同于[a-zA-Z] \l 小写字母 [a-z] \L 非小写字母 [^a-z] \u 大写字母 [A-Z] \U 非大写字母 [^A-Z] 表示数量的元字符 元字符 说明 * 匹配0-任意个 \+ 匹配1-任意个 \? 匹配0-1个 \{n,m} 匹配n-m个 \{n} 匹配n个 \{n,} 匹配n-任意个 \{,m} 匹配0-m个 \. 匹配包含换行在内的所有字符 \{-} 表示前一个字符可出现零次或多次,但在整个正则表达式可以匹配成功的前提下,匹配的字符数越少越好 = 匹配一个可有可无的项 \s 匹配空格或断行 \[] 元字符 说明 \* 匹配 * 字符。 . 匹配 . 字符。 \/ 匹配 / 字符。 \ 匹配 \ 字符。 \[ 匹配 [ 字符。 表示位置的符号 元字符 说明 $ 匹配行尾 ^ 匹配行首 < 匹配单词词首 > 匹配单词词尾 替换变量 在正规表达式中使用\\( 和 \\) 符号括起正规表达式,即可在后面使用\1、\2等变量来访问\\( 和 \\)中的内容。 懒惰模式 \{-n,m} 与\{n,m}一样,尽可能少次数地重复 \{-} 匹配它前面的项一次或0次, 尽可能地少 | “或”操作符 \& 并列 函数式 :s/替换字符串/=函数式 在函数式中可以使用 submatch(1)、submatch(2) 等来引用 \1、\2 等的内容,而submatch(0)可以引用匹配的整个内容。 与Perl正则表达式的区别 ?

元字符的区别

Vim语法Perl语法含义

\+ + 1-任意个

\? ? 0-1个

\{n,m} {n,m} n-m个 \\(\\)(和) 分组

5.综合例子

例如:

1, 去掉所有的行尾空格

:%s/\s\\+$//”。“%”表示在整个文件范围内进行替换,“\s”表示空白字符(空格和制表符),“\+”对前面的字符匹 配一次或多次(越多越好),“FCKpd0rdquo;匹配行尾(使用“\FCKpd0rdquo;表示单纯的 “FCKpd0rdquo;字符);被替换的内容为空;由于一行最多只需替换一次,不需要特殊标志。这个还是比较简单 的。(/)

IE不支持deflate[转]

| Comments

最近在做http的压缩,稍微了解了下gzip,deflate,zlib的关系:

  • deflate(RFC1951):一种压缩算法,使用LZ77和哈弗曼进行编码;
  • zlib(RFC1950):一种格式,是对deflate进行了简单的封装;
  • gzip(RFC1952):一种格式,也是对deflate进行的封装。 可以看出deflate是最核心的算法,而zlib和gzip格式的区别仅仅是头部和尾部不一样,而实际的内容都是deflate编码的,即: gzip = gzip头 + deflate编码的实际内容 + gzip尾 zlib = zlib头 + deflate编码的实际内容 + zlib尾 在HTTP/1.1的RFC2616文档中说明了Content-Encoding字段的值可以为:gzip, deflate等。 gzip格式大家都支持的很好很标准,这里说下deflate格式,Content-Encoding的说明中指出deflate指的是在RFC1950说明的zlib格式。也就是说当Content-Encoding为deflate时,内容应该为zlib格式。 但是,实际上,如果真的按照这个标准来,那么在IE上面是打不开页面的,包括IE6,IE7,IE8,提示为一片空白或者出错。但是在其他的浏览器如Firefox,Chrome,Opera等上面都能正常打开。要让IE能够正常打开页面,内容必须是deflate原始格式的数据,即去掉zlib头和zlib尾。不知道IE为什么不修改这个Bug,按理说在IE6就出现的这种很简单的问题,IE8不应该出现才对。 为了照顾IE,只好在压缩deflate的时候去掉zlib头和zlib尾,还好其他的浏览器也都能正常处理这种原始的deflate格式。 当然,这样的话,那些受够了IE Only的人们倒是可以创建出一个IE不能正常访问的网站了。