Posted by bianbian on 2008-06-19 20:08
本文Tags: bug, FTP, ftp4j, 解决
上次推荐的ftp4j在解析部分FTP站点的目录list的时候遇到了FTPListParseException(也怪FTP协议没有对LIST格式作出标准)。查看源码发现,主要是两个问题:
1)文件权限不只rwx这三个,附加了s、t(详见http://en.wikipedia.org/wiki/File_system_permissions)
2)部分ftpd似乎直接调用的“ls -l”输出目录,第一行是“total xxx”
给作者写信了,说不定下个版本就有Sepcial Thanks to bianbian 了。嘿嘿嘿嘿。。。
修正后的代码(省略后面没有变化的部分):
- public class UnixListParser implements FTPListParser {
- // bianbian.org: Pattern有问题,修正
- private static final Pattern PATTERN = Pattern
- .compile("^([dlcbsp\\-])[r\\-][w\\-][xsS\\-][r\\-][w\\-][xsS\\-][r\\-][w\\-][xtT\\-]\\s+"
- + "(?:\\d+\\s+)?\\S+\\s*\\S+\\s+(\\d+)\\s+(?:(\\w{3})\\s+(\\d{1,2}))\\s+"
- + "(?:(\\d{4})|(?:(\\d{1,2}):(\\d{1,2})))\\s+"
- + "([^\\\\/*?\"<>|]+)(?: -> ([^\\\\*?\"<>|]+))?$");
- private static final DateFormat DATE_FORMAT = new SimpleDateFormat(
- "MMM dd yyyy HH:mm", Locale.US);
- public FTPFile[] parse(String[] lines) throws FTPListParseException {
- int currentYear = new GregorianCalendar().get(Calendar.YEAR);
- int i, jump = 0, size = lines.length;
- //bianbian.org: glftpd 的第一行和 ls -l 一样,会丢个"total N"过来,先去掉
- if (size > 0 && lines[0].startsWith("total")) {
- size--;
- jump = 1;
- }
- FTPFile[] ret = new FTPFile[size];
- for (i = 0; i < size; i++) {
- Matcher m = PATTERN.matcher(lines[i + jump]);
- if (m.matches()) {
- ret[i] = new FTPFile();
- // Retrieve the data.
- char typeChar = m.group(1).charAt(0);
- String sizeString = m.group(2);
- String monthString = m.group(3);
- String dayString = m.group(4);
- String yearString = m.group(5);
- String hourString = m.group(6);
- String minuteString = m.group(7);
- String nameString = m.group(8);
- String linkedString = m.group(9);
- // Parse the data.
- if ("-cbsp".indexOf(typeChar) > -1) {
- ret[i].setType(FTPFile.TYPE_FILE);
- } else if (typeChar == 'd') {
- ret[i].setType(FTPFile.TYPE_DIRECTORY);
- } else if (typeChar == 'l') {
- ret[i].setType(FTPFile.TYPE_LINK);
- ret[i].setLink(linkedString);
- } else {
- throw new FTPListParseException();
- }
- ...
标签:
bug,
FTP,
ftp4j,
解决遵守创作共用协议,转载请链接形式注明来自
http://bianbian.org 做人要厚道
相关日志
Posted in Java, Technology | 3 Comments »
Posted by bianbian on 2008-06-03 10:25
本文Tags: 照片
都在忙一件事情:

标签:
照片遵守创作共用协议,转载请链接形式注明来自
http://bianbian.org 做人要厚道
相关日志
Posted in Not IT | 2 Comments »
Posted by bianbian on 2008-05-21 16:02
本文Tags: 区域预警, 民航, 气象
随着我国民航运输业的迅猛发展,区域预警预报的作用日益突显,对此项技术的研究已成为迫在眉睫的任务。民航气象系统应加强综合立体探测系统的建设,加快精细化航空数值预报系统的建设,通过加强实时探测资料的联网应用、建立航空危险天气要素预警预报模型和资料共享平台等手段,提高危险天气的预警和临近预报水平,为保障飞行安全、提高空域容量、提升运行效率提供辅助决策工具。
标签:
区域预警,
民航,
气象遵守创作共用协议,转载请链接形式注明来自
http://bianbian.org 做人要厚道
相关日志
Posted in Meteorology, Not IT | No Comments »
Posted by bianbian on 2008-05-16 00:30
本文Tags: gmail, google
今天偶然又发现一个gmail强悍的功能:
把exe文件改名为doc,比如cmd.exe.doc,然后当附件上载。(因为不允许直接上载exe)
然后收到以后因为是doc结尾,会列出“在 HTML 格式下查看 以 Google 文档打开 下载”功能,这时候点了“在HTML格式下查看”。我想出个乱码应该是常理。
结果,强悍的gmail取出了exe里的格式信息(exe由几个段构成,详细请查询exe文件格式,此不赘述):
WINDOWS EXECUTABLE
32bit for Windows 95 and Windows NT
Technical File Information:
Image File Header
….
Image Optional Header
….
Import Table
….
Section Table
….
Header Information
….
太强悍了~~~一个email系统能做到这个份上,google怎能不强大~~~
标签:
gmail,
google遵守创作共用协议,转载请链接形式注明来自
http://bianbian.org 做人要厚道
相关日志
Posted in Technology | 3 Comments »
Posted by bianbian on 2008-05-14 13:15
本文Tags: apache, IdP, LDAP, Shibboleth, tomcat
首先佩服老外:1)把简单的东西搞得很复杂 2)很会创造标准和协议
这次遇到的Shibboleth就是这么个东西,看了两天英文,对人为复杂、创造协议痛恨中。简单写个配置指南,给其他人做个参考,少走弯路。
注意:
1) 系统时间必须设置正确
2) apache 需要 mod_ssl mod_proxy_ajp,假设安装在 /etc/httpd
3) 必须使用 tomcat-5.5.x+,假设安装在 /opt/apache-tomcat-5.5.26
4) 如果需要改变安装目录重新安装,必须退到解压那步(否则很多和目录有关的代码不会重新编译,导致严重错误–啊!我整整一天的痛苦啊!)
# 取消tomcat的AJP身份认证
vi /opt/apache-tomcat-5.5.26/conf/server.xml
# 找到 Define an AJP 1.3 Connector 那,初始为:
- <Connector port="8009"
- enableLookups="false" redirectPort="8443" protocol="AJP/1.3" />
# 修改为(端口改变没有特殊目的,只是我系统上跑了好几个tomcat,防止冲突):
- <Connector port="8019"
- enableLookups="false" redirectPort="8443" protocol="AJP/1.3"
- request.tomcatAuthentication="false" address="127.0.0.1" />
# apache httpd 配置AJP反向代理
vi /etc/httpd/conf.d/proxy_ajp.conf
# 添加:
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
ProxyPass /idp/ ajp://localhost:8019/idp/
# 安装Shibboleth 2.0 Identity Provider (IdP)
unzip shibboleth-idp-2.0.0-bin.zip
cd identityprovider
cp endorsed/*.jar /opt/apache-tomcat-5.5.26/common/endorsed/
sh ant.sh install
# 提示是否新安装,yes
# 提示选择安装目录,/opt/idp
# 提示hostname,根据实际填写
# 提示加密密匙,随便写
# 部署war
vi /opt/apache-tomcat-5.5.26/conf/Catalina/localhost/idp.xml
# 内容:
- <?xml version="1.0" encoding="UTF-8"?>
- <Context docBase="/opt/idp/war/idp.war"
- privileged="true"
- antiResourceLocking="false"
- antiJARLocking="false"
- unpackWAR="false" />
# 测试:应该能看到“ok”
httpd -k restart
links http://127.0.0.1/idp/profile/Status
# 配置用户名/密码认证方式
vi /opt/idp/conf/handler.xml
# 找到 Login Handlers 那,注释掉”RemoteUser”认证方式,启用UsernamePassword方式。修改为:
- <LoginHandler xsi:type="UsernamePassword"
- jaasConfigurationLocation="file:///opt/idp/conf/login.config">
- <AuthenticationMethod>urn:oasis:names:tc:SAML:2.0:ac:classes:unspecified</AuthenticationMethod>
- <AuthenticationMethod>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</AuthenticationMethod>
- </LoginHandler>
# 配置LDAP连接方式
vi /opt/idp/conf/login.config
- ShibUserPassAuth {
- edu.vt.middleware.ldap.jaas.LdapLoginModule required
- host="ldap.bianbian.org"
- base="dc=test,dc=bianbian,dc=org"
- serviceUser="cn=Directory Manager"
- serviceCredential="11111111"
- subtreeSearch="true"
- userField="uid";
- };
# 配置SP(关键!加入SP的Metadata描述)
vi /opt/idp/conf/relying-party.xml
# 找到 MetadataProvider 那,注意修改id和backingFile要不同
# 假设某通过apache模块工作的SP位于 http://bianbian.org/
- <MetadataProvider id="URLMD" xsi:type="FileBackedHTTPMetadataProvider" xmlns="urn:mace:shibboleth:2.0:metadata"
- metadataURL="http://bianbian.org/Shibboleth.sso/Metadata"
- backingFile="/opt/idp/metadata/bianbian.org-metadata.xml" />
# 配置传递属性,这跟每个SP有关,要与SP联合配置
标签:
apache,
IdP,
LDAP,
Shibboleth,
tomcat遵守创作共用协议,转载请链接形式注明来自
http://bianbian.org 做人要厚道
相关日志
Posted in Java, Technology | No Comments »