CentOS 6 下OpenSSL升级到OpenSSL 1.0.1g

下载并安装OpenSSL 1.0.1g

左边的# 意思是需要root权限,实际输入命令请不要输入。

# cd /usr/src
# wget https://www.openssl.org/source/openssl-1.0.1g.tar.gz -O openssl-1.0.1g.tar.gz
# tar -zxf openssl-1.0.1g.tar.gz
# cd openssl-1.0.1g
# ./config
# make
# make install

替换系统的OpenSSL:

# rm /usr/bin/openssl
# ln -s /usr/local/ssl/bin/openssl /usr/bin/openssl
# openssl version
显示:OpenSSL 1.0.1g 7 Apr 2014

升级完成!

Fusion Drive 组建

一、       Fusion Drive 介绍

在 Apple Store 在线商店作为可配置选件提供的 Fusion Drive 是一个突破性概念,它将传统硬盘存储容量大的特点与闪存高性能的特点融合在一起。iMac 配置 Fusion Drive 之后,在执行磁盘密集型任务时,例如启动系统、启动 app 以及导入照片时,将运行地更加快速、更加高效。这是因为频繁使用的项目存储在速度更快的闪存中,不常访问的项目则存储在硬盘中。文件传输在后台进行,你甚至丝毫察觉不到。随着系统逐渐了解你的工作方式,Fusion Drive 可以为你带来更出色的 Mac 使用体验,而你不必费心做任何事。目前,Apple 可提供 1TB 和 3TB 两种容量的 Fusion Drive 供用户选择。

(更多…)

无需SHSH!iPhone4S系统降级IOS6.1.3 !

就在昨天日常的逛论坛,无意间发现了iPhone4s系统可以被降级到6.1.3,正好手上有一个可以用以降级的机器,于是乎开始着手起来,此次降级操作需要有一定计算机操作经验,以下是我记录的操作流程。

以下操作限定OSX操作系统Linux操作系统请研究odysseusOTA中的README文件。Windows目前暂不支持: )

为了保证降级一次成功,建议重新刷最新的可越狱系统,使用恢复模式进行刷机。 (更多…)

iOS判断推送权限开关是否打开

根据 [[UIApplication sharedApplication] enabledRemoteNotificationTypes] 的返回值来进行判断,该返回值是一个枚举值,如下:

typedef enum {
UIRemoteNotificationTypeNone = 0,
UIRemoteNotificationTypeBadge = 1 << 0,
UIRemoteNotificationTypeSound = 1 << 1,
UIRemoteNotificationTypeAlert = 1 << 2,
UIRemoteNotificationTypeNewsstandContentAvailability = 1 << 3,
} UIRemoteNotificationType;

如果是 UIRemoteNotificationTypeNone ,则可以认为推送开关没有打开,反之亦然。

不过在iOS8中苹果对其做出了调整,需要使用下面的代码进行判断:

if (is_ios_8) {
UIUserNotificationSettings *mySet = [[UIApplication sharedApplication] currentUserNotificationSettings];
mySet.types; // <– 这里是一个枚举值
}

枚举值有如下:

typedef NS_OPTIONS(NSUInteger, UIUserNotificationType) {
UIUserNotificationTypeNone = 0, // the application may not present any UI upon a notification being received
UIUserNotificationTypeBadge = 1 << 0, // the application may badge its icon upon a notification being received
UIUserNotificationTypeSound = 1 << 1, // the application may play a sound upon a notification being received
UIUserNotificationTypeAlert = 1 << 2, // the application may display an alert upon a notification being received
} NS_ENUM_AVAILABLE_IOS(8_0);

使用linux sendmail发送邮件

sendmail是linux/unix系统下用来发送邮件的客户端。sendmail使用SMTP协议将邮件发送到目的SMTP服务器。其工作流程大概如下:
首先要说一下DNS的MX记录:SMTP服务器基于DNS中的MX(mail exchange)记录来路由电子邮件,MX记录注册了域名和相关的SMTP中继主机,属于该域的电子邮件都应向该主机发送。

(1)Sendmail 请求DNS给出主机sh.abc.com的CNAME 记录,如有,假若CNAME(别名记录)到shmail.abc.com,则再次请求shmail.abc.com的CNAME记录,直到没有为止。
(2)假定被CNAME到shmail.abc.com,然后sendmail请求@abc.com 域的DNS给出shmail.abc.com的MX记录(邮件路由及记录),shmail MX 5 shmail.abc.com 10 shmail2.abc.com。
(3)Sendmail组合请求DNS给出shmail.abc.com的A记录(主机名(或域名)对应的IP地址记录),即IP地址,若返回值为10.0.0.4(假设值)。
(4)Sendmail与10.0.0.4连接,传送这封给user@sh.abc.com 的信到1.2.3.4 这台服务器的SMTP后台程序。

1. 构造邮件
在使用sendmail发送邮件之前,首先需要按邮件格式构造一封邮件。包括邮件头,邮件消息体。邮件格式在RFC5322:internet message format(http://tools.ietf.org/html/rfc5322)中有详细说明。

From: Lolita Demo <example@xloli.com>
Sender: Lolita Demo <example@xloli.com>
To: Zmsky <example@xloli.net>
Subject: Hello World!

This is a message just to say hello.
So, “Hello”.

2. 使用sendmail发送邮件

将邮件构造好之后,保存到一个本地文件,如/data/mail_content。然后调用sendmail发送,发送时指定接收邮箱地址:

cat /data/mail_content | sendmail example@xloli.net

 

3. 发送HTML格式的邮件

如果要发送html格式的邮件, 就是说,邮件的消息体为一个html文件,需要在邮件头中指定 content-type为 text/html。如果不指定,默认情况下,content-type为text/plain,即普通文本。

From: Lolita Demo <example@xloli.com>
Sender: Lolita Demo <example@xloli.com>
To: Zmsky <example@xloli.net>
Content-type: text/html
Subject: Hello World!

<div style=”border:solid 1px #1D448C;”>
<h1>This is a message just to say hello.</h1>
<p>So, “Hello”.</p>
</div>

佳能EOS 650D 更换顶盖修复热靴和距离感应器

购买佳能EOS650D单反相机有很长一段时间了,最近购买了品色的TTL闪光灯X650c,使用下来还是挺不错的,不过后面发现总是过曝或者欠爆,以为闪光灯出了问题,仔细研究一番发现,是TTL信息似乎没有传输过去,后面垫了张纸忍忍过去了。

可是接下来距离传感器莫名其妙的坏掉了,开机之后屏幕马上黑屏,只有按Q键或者电子取景器模式才能用屏幕,后面拆机后发现无法解决,于是乎装回去,然后无意间翻设置,找到一个叫做自动关闭屏幕的设置,关闭之后主界面不会自动黑屏了,不过连凑上去也不会黑,虽说没啥问题了,但是还是感觉不太方便。 (更多…)

TOTOLINK A2004NS 路由器最新固件升级方法

Totolink 是韩国 iptime 在中国的子品牌,A2004NS 算得上是一款性价比很好的无线路由器,拥有千兆WAN和千兆LAN,还有 USB 2.0 接口。

目前中文版的最新固件版本是 8.84,不知道为什么国外版本已经9.26了,国内一直没有动静。
不过中英文固件不能混用,直接刷韩国IPTIME官网的固件会出错,需要要先升级过度固件 a2004ns_en_8_92_mod.bin
升级成功之后再升级官网的最新固件(英文版)a2004ns_en_9_26.bin,固件版本已升级到 9.26 (截止2014年9月12日)
升级固件后,路由器管理界面变成英文(英文有障碍的请慎重),所有设置都在,无需重新设置。新固件改进了稳定性(必须的,不然还出什么新固件),部分功能有变化,自然也有新功能登场。

(更多…)

IPv6的6to4优先级设置

发现自家路由器支持IPV6于是乎很多网站不需要科学上网了,但是发现Windows默认用的IPV4,于是乎就需要做些调整。

IPv6优先,适用于XP

netsh
int
ipv6
set prefix ::1/128 50 0
set prefix ::/0 40 1
set prefix 2002::/16 30 1
set prefix ::/96 20 3
set prefix ::ffff:0:0/96 10 4
set prefix 2001::/32 5 1

APT-GET遭遇Segmentation faulty tree问题

今天继续折腾树莓派 于是乎最近问题不少,继昨天出现APT问题今天又出现,当然问题最终还是解决了,于是乎为了方便以后,果断还是再开一个文章记录下解决方案。

问题:

root@Zmsky-RpiServer:/etc/apt# apt-get upgrade
Reading package lists… Done
Segmentation faulty tree… 0%
root@Zmsky-RpiServer:/etc/apt#

解决方案:

rm -rf /var/cache/apt/*.bin

加强SSH服务器安全-公钥密钥认证

传统的SSH服务器默认是使用的Linux用户进行认证,采用帐号密码认证必然存在密码被泄漏被爆破等威胁,最近咱无聊打算研究下网络安全领域的知识,也正打算才用证书方式认证我的相关服务器,WiFi网络等。

SSH才用公钥密钥认证,实际上就是使用的RSA方式进行公钥密钥认证,至于RSA是什么,如果有兴趣的朋友想了解可以移步至维基百科,传送门在这里:http://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3%95

(更多…)

Debian/Ubuntu 安装软件出现contains empty filename解决方案

今天咱又在敲鼓着咱的树莓派(Raspberry Pi) 打算做一个Radius服务器以及SSH服务器证书,正按照网上各种教程配置,当我走到APT步骤的时候总是出现以下错误,使用以前惯用的几个方法都不行。

 dpkg: unrecoverable fatal error, aborting:
 files list file for package `libdirac-encoder0:armhf' contains empty filename
E: Sub-process /usr/bin/dpkg returned an error code (2)'

(更多…)

让nginx支持ThinkPHP

近日将自己的一个ThinkPHP项目发布到服务器上,发现各种404问题,查询相关资料后发现为Nginx不支持Pathinfo模式,最终采用重定向方法解决。

通过官方资料查询

访问 http://domain/index.php/Index/Login 实际上是访问 http://domain/index.php?s=Index/Login

既然这是典型的URL重定向,那么就可以直接修改nginx的conf文件进行兼容 (更多…)