• Composer使用中常见的问题


    安装了Composer后,运行 composer --version ,查看Composer的版本号。如果出现下面的提示,那么软件安装成功。

    Composer version 1.2.0 2016-07-19 01:28:52

    若想给某个项目添加类似monolog的第三方库,则按下面的步骤操作:

    新建composer.json文件,添加内容:

    { "require": { "monolog/monolog": "1.20.0" }, "repositories": { "packagist": { "type": "composer", "url": "https://packagist.phpcomposer.com" // Mirror site in China. } } }

    以命令行方式打开项目的根目录,输入命令: composer install ;

    正常情况下,一切顺利,执行完上述命令就能够成功导入 monolog 库到项目中。但是,现实与想象总是有段距离,上面只是走完了“长征”路程的一半,还有“雪山”要翻、“草地”要过呢!

    执行完命令: composer install 后,并不会像期待那样地导入依赖,而是抛出异常。

    The openssl extension is required for SSL/TLS protection but is not available. If you can not enable the openssl exension, you can disable this error, at your own risk, by setting the 'disable-tls' option to true.

    这段异常日志的大致意思是,Composer采用SSL连接,需要外挂OpenSSL插件。

    要消除这个异常,有两种解决方式,一是放弃SSL连接、直接“裸奔”;二是启用OpenSSL。

    取消SSL连接的命令是 composer config -g -- disable-tls true 。然而并没有什么卵用,试过之后,又抛出了新的异常。

    剩下来的方案就是尝试启用OpenSSL。安装�php后,安装目录(类似C:php-5.6.24)中包含两个文件,一个是php.ini-development,另一个是php.ini-production,选择将其中任意的一个文件重命名为php.ini,用作PHP的默认配置文件。通过修改配置文件来启用OpenSSL插件。

    编辑php.ini文件,首先,定位到:

    ; Directory in which the loadable extensions (modules) reside. ; http://php.net/extension-dir extension_dir = "./" ; On windows: extension_dir = "ext"

    删除 extension_dir = "./" 和 extension_dir = "ext" 前面的分号,取消注释这两行代码,配置PHP插件目录为 ./ext 。

    然后,定位到:

    ... ;extension=php_mysqli.dll ;extension=php_oci8_12c.dll ; Use with Oracle Database 12c Instant Client extension=php_openssl.dll ;extension=php_pdo_firebird.dll ;extension=php_pdo_mysql.dll ;extension=php_pdo_oci.dll ;extension=php_pdo_odbc.dll ...

    删除 extension=php_openssl.dll 前面的分号,取消注释,从而启用OpenSSL插件。

    注意:因为SSL连接需要认证,所以继续下面的步骤之前,需要准备好CA证书(建议把证书保存到 C:php-5.6.24verify 目录中),可以从 https://curl.haxx.se/docs/caextract.html 处下载。

    接下来,定位到

    ;openssl.cafile=

    和上面一样,删去分号,取消注释,设置CA证书为 openssl.cafile= C:php-5.6.24verifycacert.pem 。

    最后, 重新在命令行窗口中打开项目的根目录,执行命令: composer install ,等待几分钟后,就可以成功添加 monolog 依赖。

  • 相关阅读:
    Flink RichSourceFunction应用,读关系型数据(mysql)数据写入关系型数据库(mysql)
    基于Filebeat+Kafka+Flink仿天猫双11实时交易额
    Flink消费Kafka数据并把实时计算的结果导入到Redis
    Flink+kafka实现Wordcount实时计算
    Filebeat+Kafka+Logstash+ElasticSearch+Kibana搭建完整版
    spring boot+mybatis+quartz项目的搭建完整版
    Hadoop生态组件Hive,Sqoop安装及Sqoop从HDFS/hive抽取数据到关系型数据库Mysql
    Swagger+AutoRest 生成web api客户端(.Net)
    NodeJS学习
    Go学习
  • 原文地址:https://www.cnblogs.com/2881064178dinfeng/p/6215564.html
Copyright © 2020-2023  润新知