2017年8月

一 、

设置Git的user name和email:

$ git config --global user.name "yourName"

$ git config --global user.email "yourEmail"

二、生成SSH密钥过程:
1.查看是否已经有了ssh密钥:cd ~/.ssh
如果没有密钥则不会有此文件夹,有则备份删除
2.生存密钥:

$ ssh-keygen -t rsa -C "yourEmail"
按3个回车,密码为空。

如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。
我们要添加的就是公钥

ftp文件上传

php自带有ftp操作的函数包,一个比较简单实现的ftp文件上传操作可以通过以下几个步骤来完成:

1、确认ftp server的ip地址与port端口信息(如果使用的是默认端口则可以不关心);
2、进行ftp_connect操作,连接到ftp server(需要注意一下是否设置了port参数);
3、进行ftp_login操作,使用ftp用户名和密码进行登录;
4、这里开始区分,如果只需要把文件上传上去,没有其它要求的话,那在这里就可以进行文件上传的ftp_put操作了;如果对上传文件有按照目录存放的需求,那就继续向下进行;
5、使用ftp_nlist获取到给定的ftp目录下的目录与文件名称,检查一下需要的目录是否存在,若不存在则需要进行ftp_mkdir创建目录;
6、 切换到目标目录中ftp_chdir;
7、进行ftp_put操作上传文件;
8、进行ftp_close关闭ftp连接。

以在ftp中按照日期格式目录来进行上传文件的需求,做一个简单的代码实现:

$user = 'uftp';
$pwd = 'uftp';
 
// 进行ftp连接,根据port是否设置,传递的参数会不同
if(empty($port)){
    $f_conn = ftp_connect($host);
}else{
    $f_conn = ftp_connect($host, $port);
}
if(!$f_conn){
    echo "connect fail\n";
    exit(1);
}
echo "connect success\n";
 
// 进行ftp登录,使用给定的ftp登录用户名和密码进行login
$f_login = ftp_login($f_conn,$user,$pwd);
if(!$f_login){
    echo "login fail\n";
    exit(1);
}
echo "login success\n";
 
// 获取当前所在的ftp目录
$in_dir = ftp_pwd($f_conn);
if(!$in_dir){
    echo "get dir info fail\n";
    exit(1);
}
echo "$in_dir\n";
 
// 获取当前所在ftp目录下包含的目录与文件
$exist_dir = ftp_nlist($f_conn, ftp_pwd($f_conn));
print_r($exist_dir);
 
// 要求是按照日期在ftp目录下创建文件夹作为文件上传存放目录
echo date("Ymd")."\n";
$dir_name = date("Ymd");
// 检查ftp目录下是否已存在当前日期的文件夹,如不存在则进行创建
if(!in_array("$in_dir/$dir_name", $exist_dir)){
    if(!ftp_mkdir($f_conn, $dir_name)){
        echo "mkdir fail\n";
        exit(1);
    }else{
        echo "mkdir $dir_name success\n";
    }
}
// 切换目录
if(!ftp_chdir($f_conn, $dir_name)){
    echo "chdir fail\n";
    exit(1);
}else{
    echo "chdir $dir_name success\n";
}
// 进行文件上传
$result = ftp_put($f_conn, 'bbb.mp3', '/root/liang/ftp/bbb.mp3', FTP_BINARY);
if(!$result){
    echo "upload file fail\n";
    exit(1);
}else{
    echo "upload file success\n";
    exit(0);
}

打印:
`root@webdevelop232:~/liang/ftp# php ftp.php
connect success
login success
/home/uftp
Array
(
[0] => /home/uftp/Kalimba.mp3
[1] => /home/uftp/test.txt
)
20170721
mkdir 20170721 success
chdir 20170721 success
upload file success


可以看到打印的操作成功了,这时候去ftp server的目录下,就能够看到上传的文件了。

ftp文件下载

相对于文件上传来讲,使用php来进行ftp文件下载的实在是不多见,但既然有这个功能,就说明总可能会有人使用,所以也做一个简单的示例。
就以上面上传的bbb.mp3文件为下载目标来进行操作,把它下载到当前目录,命名为1.mp3:

$host = '10.0.0.42';
$uname = 'uftp';
$upwd = 'uftp';

// 进行ftp连接
if(empty($port)){
$f_conn = ftp_connect($host);
}else{
$f_conn = ftp_connect($host, $port);
}
if(!$f_conn){
echo "ftp connect fail\n";
exit(1);
}
// 进行ftp登录
if(!ftp_login($f_conn, $uname, $upwd)){
echo "ftp login fail\n";
exit(1);
}
// 进行ftp下载
if(!ftp_get($f_conn, './1.mp3', ftp_pwd($f_conn).'/'.date('Ymd').'/bbb.mp3', FTP_BINARY)){
echo "ftp download fail\n";
exit(1);
}else{
echo "ftp download success\n";
exit(0);
}

1、以teacher_id进行分组并且查出每个分组里有多少成员

//如果有where条件就在Dbname后加入where条件即可
SELECT COUNT(*) AS every_group_nums FROM DBname GROUP BY teacher_id;

2、以teacher_id进行分组,然后查出一共有多少个分组

//必须有(AS a)//a是随便起的
SELECT COUNT(*) AS all_groups FROM (SELECT teacher_id FROM Dbname GROUP BY teacher_id) AS a;

安装了好几回,官方提示的权限是不全的,总有那么几个是更新的时候写入失败,大致就这些,如图:
1502950908(1).png

根目录/和data目录是必须给的,系统会提示,剩下的有:
web
web/re
fram
fram/lib
app
app/res
命令行下给这几个权限,就哦了

class为po的某元素必须给绝对定位,不能是fixed
        $(window).scroll(function(){//时刻监听滚动事件
        var top=$(window).scrollTop();//获取当前滚到的位置
                    //po为某个div,只给个top就可以,但是如果不给固定高度的话到底部之后鼠标还能往下滚
                    //必须给stop
                    $('.po').stop().animate({top:top+50,height:'550px'});
    })