我从域名a的网站里写个ajax,要请求域名b下的接口数据,很明显,跨域了,普遍的解决方法有两种:

1、jsonp
网上方法一大堆,我不写了,而且我不用这个方法.......因为jsonp的话传参只能是get,所以我不用。
2、增加header头
简单易用,一行代码搞定,利用 CORS,域名b下对应的接口方法里只需添加一个标头,就可以允许来自 域名a 的请求:
PHP:header("Access-Control-Allow-Origin:*");
Java:response.addHeader("Access-Control-Allow-Origin","*");
打开调试工具,如果请求头信息里有Access-Control-Allow-Origin:*,就表示CORS已经启用成功了;
06082242-c70a37f237ed48c4a60d33fccfd467fb.png
此时,你的ajax返回的数据就能接收到了,happy~~~
  • PS:第二种方法注意下安全问题,因为你允许任何域名都可以访问,PHP可以设置指定哪些域名可以访问,比如:

    PHP:("Access-Control-Allow-Origin:http://www.a.com");
  • PS2:因为我不是Javaer,所以Java的指定方式不敢妄说,请各路大神解决~~~

    Java:response.addHeader("Access-Control-Allow-Origin","http://www.a.com");貌似这样是可以滴;

原因:人人商城的代码存放在客户的服务器上,用的域名是自己的二级域名,突然自己的二级域名不能用了(被举报了),客户的微信公众号端客户就不能访问了,而且上传了很多商品了,还得保留数据。
我用的是oneinstack

1、新解析个好的域名,比如访问到now目录下,之前的到before目录
2、把before目录改成now,把now改成before(这样新的域名就指定到了之前的代码目录下,数据库也没有变,数据完整)
3、登录新的域名下发现接口地址已经变成了现在的新的域名,只需要改几个地方:
  • 微信公众平台里把功能设置里的授权域名改成现在的域名
  • 配置里的url改成新的域名(&id=9这部分不动),token和EncodingAESKey保持不变
  • 现在把之前的菜单动作的链接改到现在的域名下就可以了,参数都不动,只改域名

    4、如果有支付参数,再到微信商户里把支付授权目录改下就哦了
    到此,整站迁移完成

一 、

设置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;