要让mysql查询区分大小写,可以:
- select * from table_name where binary a like ‘a%’
- select * from table_name where binary a like ‘A%’
也可以在建表时,加以标识
create table table_name(
a varchar (20) binary
)
要让mysql查询区分大小写,可以:
也可以在建表时,加以标识
create table table_name(
a varchar (20) binary
)
如果使用CURL下载从微信手机端上传的图片?参考下面代码
/** * CURL下载文件 成功返回文件名,失败返回false * @param $url * @param string $savePath * @return bool|string * @author Zou Yiliang */ public function downFile($url, $savePath = './uploads') { //$url = 'http://www.baidu.com/img/bdlogo.png'; /* HTTP/1.1 200 OK Connection: close Content-Type: image/jpeg Content-disposition: attachment; filename="cK4q4fLsp7YOlaqxluDOafB.jpg" Date: Sun, 18 Jan 2015 16:56:32 GMT Cache-Control: no-cache, must-revalidate Content-Length: 963704 */ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HEADER, TRUE); //需要response header curl_setopt($ch, CURLOPT_NOBODY, FALSE); //需要response body $response = curl_exec($ch); //分离header与body $header = ''; $body = ''; if (curl_getinfo($ch, CURLINFO_HTTP_CODE) == '200') { $headerSize = curl_getinfo($ch, CURLINFO_HEADER_SIZE); //头信息size $header = substr($response, 0, $headerSize); $body = substr($response, $headerSize); } curl_close($ch); //文件名 $arr = array(); if (preg_match('/filename="(.*?)"/', $header, $arr)) { $file = date('Ym') . '/' . $arr[1]; $fullName = rtrim($savePath, '/') . '/' . $file; //创建目录并设置权限 $basePath = dirname($fullName); if (!file_exists($basePath)) { @mkdir($basePath, 0777, true); @chmod($basePath, 0777); } if (file_put_contents($fullName, $body)) { return $file; } } return false; }
1. 去官网下载jdk.
http://download.oracle.com/otn/java/jdk/6u45-b06/jdk-6u45-linux-x64.bin
2.su root //切换到root账户
3. mkdir /usr/java // 在usr目录下创建java文件夹
4. mv jdk-6u45-linux-x64.bin /usr/java //将下载的jdk文件移动到你刚创建的文件夹下 前提是在你下载jdk所存放的目录下
5. chmod 777 jdk-6u45-linux-x64.bin //给安装包执行权限 前提是要在/usr/java目录下
6. ./jdk-6u45-linux-x64.bin //安装 出现none 时安装成功
7. vi /etc/profile // 设置环境变量
在文件最后加上
export JAVA_HOME=/usr/java/jdk1.6.0_45
export CLASSPATH=.:%JAVA_HOME%/lib/dt.jar:%JAVA_HOME%/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin
按Esc键退出 输入 :wq
注意:linux环境变量的分隔符是冒号“:”不是分号“;”
之后重启机器 reboot
最后输入 java -version 查看安装jdk版本
java version “1.6.0_45”
Java(TM) SE Runtime Environment (build 1.6.0_45-b06)
Java HotSpot(TM) 64-Bit Server VM (build 20.45-b01, mixed mode)
group_concat能将相同的行组合起来
MySQL中group_concat函数
完整的语法如下:
group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])
基本查询
select * from aa;
+——+——+
| id| name |
+——+——+
|1 | 10|
|1 | 20|
|1 | 20|
|2 | 20|
|3 | 200 |
|3 | 500 |
+——+——+
6 rows in set (0.00 sec)
以id分组,把name字段的值打印在一行,逗号分隔(默认)
select id,group_concat(name) from aa group by id;
+——+——————–+
| id| group_concat(name) |
+——+——————–+
|1 | 10,20,20|
|2 | 20 |
|3 | 200,500|
+——+——————–+
3 rows in set (0.00 sec)
以id分组,把name字段的值打印在一行,分号分隔select id,group_concat(name separator ‘;’) from aa group by id;
+——+———————————-+
| id| group_concat(name separator ‘;’) |
+——+———————————-+
|1 | 10;20;20 |
|2 | 20|
|3 | 200;500 |
+——+———————————-+
3 rows in set (0.00 sec)
以id分组,把去冗余的name字段的值打印在一行,
select id,group_concat(distinct name) from aa group by id;
+——+—————————–+
| id| group_concat(distinct name) |
+——+—————————–+
|1 | 10,20|
|2 | 20 |
|3 | 200,500 |
+——+—————————–+
3 rows in set (0.00 sec)
以id分组,把name字段的值打印在一行,逗号分隔,以name排倒序
select id,group_concat(name order by name desc) from aa group by id;
+——+—————————————+
| id| group_concat(name order by name desc) |
+——+—————————————+
|1 | 20,20,10 |
|2 | 20|
|3 | 500,200|
+——+—————————————+
3 rows in set (0.00 sec)
测试sql,项目中用到的:
update cms_brand as a join (select relation_id, group_concat(name) as new_name from cms_brand where relation_id !=0 group by relation_id ) as b on a.id=b.relation_id set name_search = concat(concat(a.name,','),b.new_name)
//xss攻击演示代码 $str = '<img src="http://www.baidu.com/img/bdlogo.png" width="180" onload="window.location=\'http://www.baidu.com\'">'; //echo $str; //页面自动跳转到baidu.com $p = new CHtmlPurifier(); $str = $p->purify($str); echo $str; //已是安全代码
单独使用
require_once __DIR__ . ‘/HTMLPurifier.standalone.php’;
$html = ‘test‘;
$config = HTMLPurifier_Config::createDefault();
//HTMLPurifier的配置文档主要是两级分类:
//大类分Attr(属性)、HTML(html标签)、AutoFormat(自动格式)、CSS(css配置)、Output(输出配置)
//小类选择通过大类名称加.加小类名称可以完成
//过滤掉所有html标签很简单,原因则在白名单机制完成
$config->set(‘HTML.Allowed’, ”);
//配置允许的html标签
$config->set(‘HTML.Allowed’, ‘p,a,b,span’);
//保留超链接标签a及其href链接地址属性
$config->set(‘HTML.Allowed’, ‘a[href]’);
//并自动添加target属性值为’_blank’
$config->set(‘HTML.TargetBlank’, true);
// 让文本自动添加段落标签,前提是必须允许P标签的使用
//$config->set(‘HTML.Allowed’, ‘p’);
//$config->set(‘AutoFormat.AutoParagraph’, true);
//$config->set(‘HTML.Allowed’, ‘p,a,b,span’);
// 清除空标签
$config->set(‘AutoFormat.RemoveEmpty’, true);
$purifier = new HTMLPurifier($config);
$html = $purifier->purify($html);
echo htmlspecialchars($html);
MySQL
SELECT TO_BASE64(‘abc’), FROM_BASE64(TO_BASE64(‘abc’)); (测试MySQL版本 5.6.20)
PHP
base64_encode(‘abc’);
base64_decode(‘abc’)
UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而Mysql的utf8编码最多3个字节,所以数据插不进去。
解决方案:将Mysql的编码从utf8转换成utf8mb4。
CREATE TABLE IF NOT EXISTS we_contact( `id` INT AUTO_INCREMENT PRIMARY KEY, `openid` VARCHAR(50) NOT NULL COMMENT '用户标识', `nickname` VARCHAR(500) NOT NULL DEFAULT '' COMMENT '昵称' )ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
对于已建好的表
转换成utf8mb4 命令:ALTER TABLE `TABLE_NAME` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; (将TABLE_NAME替换成你的表名) 将需要使用emoji的字段设置类型为: 命令:ALTER TABLE `TABLE_NAME`MODIFY COLUMN `COLUMN_NAME` text CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
使用 java连接数据库时
在Connector/J的连接参数中,不要加characterEncoding参数。 不加这个参数时,默认值就时autodetect。
使用PHP
SET NAMES 'utf8mb4';
例如Yii框架中 db=>array('connectionString' => '...', 'charset' => 'utf8mb4' ),
测试MySQL版本
Server version: 5.6.20
在Linux下,我们可以使用ntpdate进行网络时间的同步,而不是我们自己去设置时间。这个命令的使用很简单
ntpdate 0.cn.pool.ntp.org
定时的同步时间
vim /etc/crontab
10 5 * * * root (/usr/sbin/ntpdate 0.cn.pool.ntp.org && /sbin/hwclock -w) &> /var/log/ntpdate.log
每天的5点10分crontab运行一次命令,自动同步时间。
如果你具有多台的服务器,不要使用这个方法来定时的同步的你服务器,请使用ntpd
来进行,这个还可以校准始终的问题。详情查看鸟哥。
使用ntpdata
造成的时间的越变还可能引发因某些依赖连续时间的程序的问题。一般第一次使用ntpdate,接下来使用ntpd
服务来不断的调整时间。参见http://blog.sina.com.cn/s/blog_3f3422fd0100f06c.html。
将时区设置为东8区的时间,虽然服务器在全球的不同地方,但是我们人在中国,看着中国的时间比较有感觉。
另外如果使用date命令查看时间,发现刚刚好相差8个小时或者其他的小时,那么应该就是你的时区设置不对,快快修改一下吧。
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
date
# Mon Mar 31 11:02:55 CST 2014
全球那么多的网络时间同步器,那么使用哪个好呢。我们知道数据在网络上流动是由延迟的,因此我们选择离我们服务器越近的服务器进行同步,时间越准。
时间服务器分为两种,一种是一级时间服务器
,另外一种是二级时间服务器
。我们如果是同步自己的服务器的时间,那么选择二级时间服务器
,因为一级时间服务器是为二级时间服务器提供时间校对服务器,我们尽量不要增加一级服务器的压力。这种层级的概念和DNS的层级
概念是一致的。
一级时间服务器列表:http://support.ntp.org/bin/view/Servers/StratumOneTimeServers
二级时间服务器列表:http://support.ntp.org/bin/view/Servers/StratumTwoTimeServers
附二级服务器列表:
本机
ssh-keygen -t rsa (后面3个直接回车即可)
cd ~/.ssh
ls
发现创建了2个文件 id_rsa(私钥) id_rsa.pub (公钥)
将公钥复制到服务器上对应用户宿主目录/.ssh/authorized_keys中
chmod 600 ~/.ssh/authorized_keys
chmod 700 ~/.ssh
有时,我们需要将服务器上的某个目录打包,以方便我们下载传输。
例如 备份/data/webroot/uploads下所有文件,但要排除/data/webroot/uploads/temp目录。代码如下:
cd /data/webroot/ date=`date +%Y%m%d` /bin/tar -zcvf /data/backup/uploads.${date}.tar.gz --exclude=uploads/temp uploads