web配置简单实现方法,验证码不显示只有一个小红叉的解决方法
分类:web前端

最近想自学PHP ,做了个验证码,但不知道怎么搞的,总出现一个如下图的小红叉,但验证码就是显示不出来,原因如下

1.使用数据库事务的时候需要传递参数,使用了use关键字,否则的话传递不进去,代码如下:

1.搭建基本的web环境,我使用的是apache2 + php5 + mysql 5.0
apt-get install apache2 mysql-server-5.0 php5-mysql
2.解决用户登录时图形验证码无法显示的问题
apt-get install php5-gd
3.安装mysql的web管理软件phpmyadmin
apt-get install phpmyadmin
4.安装Zend Optimizer
wget
以root身份执行./install.sh
其中会要求指定你的php.ini的位置,默认的情况下都会放在/etc/php5/apache2里面,填进去就可以了
5.配置apache虚拟主机
打开/etc/apache2/apache2.conf,在最后添加如下代码:
# VirutalHost Server
NameVirtualHost 127.0.0.1
<VirtualHost 127.0.0.1>
servername www.myweb.com
documentroot /var/www/webfolder/
</VirtualHost>
(T002) 图片 1

未修改之前,出现如下错误;
图片 2 
(1)修改步骤如下,原因如下,原因是apache权限没开,
图片 3 
(2)点击打开php.int.,
搜索extension=php_gd2.dll
打开?去掉前面分号重启apache,就OK了 ,万事大吉了。
图片 4 
希望各位朋友遇到这样的问题的时候,能给与帮助

    public function postVote(Request $request){
        $data = $request->all();
        $count = DB::table("vote")->where("workdid",$data['id'])->where("ip", $data['ip'])->count();


        if(DB::table("vote")->where("workdid",$data['id'])->where("ip", $data['ip'])->count()>0){
            $ret = ['state' => 'fail', 'message' => '您已经给这个作品投过一票!'];
        }else{
            DB::transaction(function () use($data){
                DB::table("work")->where("id", $data["id"])->increment("vote");
                DB::table("vote")->insert(["workdid"=>$data["id"], "ip"=>$data['ip']]);
            });
            $ret = ['state' => 'success', 'message' => '投票成功'];
        }
        return response()->json($ret);
    }

 

2.分页的时候需要把参数带进去,使用appends()方法,还要显示总共多少条记录,代码如下,前提是$list是查询构建起调用paginate()方法返回的结果

        <div class="summary">
            共有 {{$list->total()}} 条数据
        </div>
        @if ($list->hasPages())
            <div class="pager">
                {!! $list->appends($appends)->render() !!}
            </div>
        @endif

 

3.向主页面中追加内容的时候,主页面内容如下

@section('sidebar')
    This is the master sidebar.
@show

子页面内容如下:

@section('sidebar')
    @parent
    <p>This is appended to the master sidebar.</p>
@endsection

注意主页面@section的结束语句是@show,不是@endsection,同时子页面中使用@parent表明是追加的内容

 

4.很多javascript框架使用{{}}来表示要输入到浏览器中的表达式,可以使用@告诉blade引擎该表达式保持原生格式不做改动例如:

<h1>Laravel</h1>
Hello, @{{ name }}.

就是说如果要使用javascript框架中使用到{{}},那么前面要加@

 

5.Laravel5路由home 无法访问
在apache配置文件中将所有的 AllowOverride none;设置为AllowOverride all;配置文件具体位置因系统不同而改变,ubuntu14.0.1LTS 版本在/etc/apache2/apache2.conf文件中

 

6.部署好之后500错误

安装完laravel后,打开马上出现了500错误,配置都是正确的,但是出现了500错误
------------------>`500 (Internal Server Error)`
要给缓存文件设置777权限,如下
chmod -R 777 storage (给storage 777权限)

 

7.仅能有一个AI
有一次使用php artisan migrate ------->结果报错了
原因是主键id是AI,而设置一个外键xx_xx_id是integer类型,这就冲突了,解决方法只需将xx_xx_id改为unsigned integer类型
(像这样的$table->integer('role_id')->unsigned();)

 

8.邮件发送530错误
邮箱发送出现了如下问题:Expected response code 250 but got code "530", with message "530 5.7.1 Authentication required,
从错误吗中看出是配置错误,但是我们检查了几次都是正确的,原因是缓存问题,这时候可以
清除缓存php artisan cache:clear或重启服务器php artisan serv

 

9.使用create插入数据错误

如果使用create出现MassAssignmentException in Model.php line 448

从错误中看出是模型中没有定义白名单字段,解决如下:

class Contacts extends Model
{
  protected $fillable = ['name', 'mobile', 'email', 'address', 'created_at', 'updated_at'];
}

 

10.compose update报错
错误为:Fatal error: Uncaught exception 'ReflectionException' with message 

解决方法可能如下:

  1. composer dump-autoload
    2. 配置文件错误,需修改,如我安装时改了配置文件.env,然后报错,这时候还原.env 就正常了

11.默认情况下刀片语法的{{}}已经通过php的htmlentitys函数处理避免XSS攻击,如果不想数据被处理,显示原生的数据可以用下面的方法

Hello, {!! $name !!}.

 

12.运行命令php artisan migrate莫名其妙的错误

        Schema::create('posts', function (Blueprint $table) {
            $table->increments('id');
            $table->string('slug')->unique();
            $table->string('title');
            $table->text('content');
            $table->timestamps();
            $table->timestamps('updated_at')->index();
        });

这样会报错: 

[SymfonyComponentDebugExceptionFatalThrowableError]
Fatal error: Call to a member function index() on null

改成下面就好了

        Schema::create('posts', function (Blueprint $table) {
            $table->increments('id');
            $table->string('slug')->unique();
            $table->string('title');
            $table->text('content');
            $table->timestamps();
            $table->timestamps('published_at')->index();
        });

 

 13.修改phpstorme中的编码格式
FILE->Setting->Editor->File Encoding->将UTF-8改成GBK 

图片 5

 

14.laravel命令集合
1)查看应用中所有的路由:php artisan route:list
2)创建控制器: php artisan make:controller BlogController --plain    --plain参数表示命令用于创建一个空的控制器而不是标准的 RESTful 风格控制器
3)创建model: php artisan make:model --migration Post   创建Post模型并创建迁移文件
4)创建中间件:php artisan make:middleware OldMiddleware 创建一个OldMiddleware的中间件

 

15.定义一个token,妈蛋记不住

{'_token': '{{ csrf_token() }}', 'dir': 'product'}

{{ csrf_field() }}

<meta name="csrf-token" content="{{ csrf_token() }}">

$.ajaxSetup({
    headers: {
        'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
    }
});

 

 16.使用captcha验证码第三方插件的时候验证随机数是否正确,写法如下

        $data = $request->all();
        $attributes = [
            'name'=>'用户名',
            'password'=>'密码',
            'captcha' =>'验证码'
        ];
        $validator = Validator::make(
            $data,
            [
                'name' => 'required',
                'password' => 'required',
                'captcha' => 'required|captcha',
            ],
            [
                'required' => ":attribute不能为空",
                'captcha.required' => '请输入验证码',
                'captcha.captcha' => '验证码错误,请重试'
            ],
            $attributes
        );

 

17.发送手机验证码的时候使用validator验证手机验证码是否正确

发送验证码代码如下

    public function postValidatecode(Request $request){
        $data = $request->all();
        $code = rand(1000, 9999);
        session([config('session.session_key.register')=>$code]);
        $content = "您好,您本次注册的验证码是" . $code . ',请妥善保管。';
        $result = sendsms($data['mobile'], $content);
        return Response::json($result);
    }

验证这个验证码是否正确如下

        $data = $request->all();
        $attributes = [
            'name'=>'用户名',
            'password'=>'密码',
            'password_confirmation'=>'确认密码',
            'mobile'=>'手机号',
            'idNo'=>'身份证号',
            'validateCode'=>'验证码',
        ];
        $rules = [
            'name'=>'required|unique:users',
            'password' => array('bail', 'required', 'confirmed', 'regex:/^w{6,15}$/'),
            'password_confirmation' => 'required',
            'mobile' => array('required','regex:/^1[3|4|5|6|7|8|9]d{9}$/', 'unique:users'),
            'validateCode'=>array('required', 'validatesmsg:register'),
            'idNo'=> array('required','regex:/^d{6}(18|19|20)?d{2}(0[1-9]|1[12])(0[1-9]|[12]d|3[01])d{3}(d|X|x)$/i'),
            'agree' => 'required',
        ];

appProvidersAppServiceProvider.php中的扩展方法如下,原理很简单就是验证这个session是否相等

class AppServiceProvider extends ServiceProvider
{
    /**
     * Bootstrap any application services.
     *
     * @return void
     */
    public function boot()
    {
        //
        Validator::extend('validatesmsg', function($attribute, $value, $parameters){
            return $value == session(config('session.session_key.'.$parameters[0]));
        });
    }

    /**
     * Register any application services.
     *
     * @return void
     */
    public function register()
    {
        //
    }
}

 

本文由10bet手机官网发布于web前端,转载请注明出处:web配置简单实现方法,验证码不显示只有一个小红叉的解决方法

上一篇:PHP设置一边执行一边输出结果的代码 下一篇:没有了
猜你喜欢
热门排行
精彩图文