This article mainly introduces the method of using redis in PHP framework CodeIgniter. It has certain reference value. Now I share it with you. Friends in need can refer to it
The example in this article describes how the PHP framework CodeIgniter uses redis. Share it with everyone for your reference, the details are as follows:
1. Install redis
First of all, the redis service (redis database) must be installed and running on the computer. For details, see another article: http://www.jb51.net/article/138173.htm
2. Install phpredis
① Download
Project address: https://github.com/phpredis/phpredis (you can ignore this). It is mentioned here that the Windows version of phpredis needs to be compiled by yourself. Of course, we cannot be so reckless.
Let me talk about the detours I have taken. I downloaded it from http://windows.php.net/downloads/pecl/snaps/redis/20160319/ (you can ignore this), but I still can’t get it right. In fact, this vc14 is For the 7.0 version of PHP, what we need is the 7.1 version, so it is always wrong and we can’t find the problem until we find this:
http://pecl.php.net/package-stats.php
Click on the corresponding version:
http://pecl.php.net/package/redis/3.1.1/windows
Download the version corresponding to 7.1.
② Installation
Place the downloaded and decompressed php_redis.dll in the ext of the php interpreter. You will find that mysql and other modules are also placed here, then open php.ini and find ;extension=php_bz2.dll
, add extension=php_redis.dll
,
above it That is, add the redis configuration at the head of the extension's configuration area. The installation is complete.
③ View configuration information
Restart the server or computer, add a view page under the path of index.php: phpinfo.php, and add:
<?php echo phpinfo(); ?>
Then visit http://yourdomain.com/phpinfo.php, you can see the configuration information, and look for any information indicating successful redis configuration. If so, the configuration is complete.
3. Use PHP native method to operate redis
// 原生redis类库,不需要config/redis.php $redis = new Redis(); $redis->connect('127.0.0.1',6379); //$redis->set('key10','xx10',20);//第三个参数是存续时间,单位是秒,如果不填则为永久 echo $redis->get('key10');
4. Configure redis.php
Create the file redis.php under myApplication/config:
<?php defined('BASEPATH') OR exit('No direct script access allowed'); /** * Created by PhpStorm. * Date: 2017/2/9 * Time: 13:32 */ $config['socket_type'] = 'tcp'; $config['host'] = '127.0.0.1'; $config['password'] = NULL; $config['port'] = 6379; $config['timeout'] = 0; ?>
This configuration file is required whether you are using the framework's redis library or the custom redis library below.
In addition to configuring redis.php, you must also configure The cache type we use is configured in application/config/config.php. The default is like this:
$config['sess_driver'] = 'files'; $config['sess_cookie_name'] = 'ci_session'; $config['sess_expiration'] = 7200; $config['sess_save_path'] = NULL; $config['sess_match_ip'] = FALSE; $config['sess_time_to_update'] = 300; $config['sess_regenerate_destroy'] = FALSE;
If we use redis, then we need to configure it like this:
$config['sess_driver'] = 'redis'; $config['sess_cookie_name'] = 'ci_session'; $config['sess_expiration'] = 0; $config['sess_save_path'] = 'tcp://127.0.0.1:xxxx'; $config['sess_match_ip'] = FALSE; $config['sess_time_to_update'] = 600; $config['sess_regenerate_destroy'] = TRUE;
5. Using the redis library of the CI framework
// 框架的redis库 $this->load->driver('cache'); $this->cache->redis->save('key11','xx11');//这里注意,第三个参数是时间,在自定义redis库会说明 echo $this->cache->redis->get('key11');
6. Use a custom redis class library
① Rediscli_default.phpThe custom redis class library can be copied from system/libraries/Cache/drivers/Cache_redis.php and renamed Rediscli_default.php. The class name is also changed to Rediscli_default. Other than that, no changes are needed. You can add more methods yourself. Place it under myApplication/libraries/Rediscli/drivers/
② Rediscli.php
Create a Rediscli.php under myApplication/libraries/Rediscli/
<?php defined ( 'BASEPATH' ) or exit ( 'No direct script access allowed' ); /** * Created by PhpStorm. * Date: 2017/2/9 * Time: 20:00 */ class Rediscli extends CI_Driver_Library { public $valid_drivers; public $CI; function __construct() { $this->CI = & get_instance (); $this->valid_drivers = array ( 'default' ); } }
③ Call
// 自定义类,需要配置 $this->load->driver('rediscli'); if ($this->rediscli->default->is_supported()) { echo $this->rediscli->default->get('key2'); }
④ Time
This custom redis library is the same as the framework library, so we will focus on it here.
$this->cache->redis->save('key11','xx11',1000);
This is the saved value. The third parameter is the time, which cannot be omitted. By looking at the function, you can see that the default value of this parameter is 60 seconds, not permanent, so this parameter cannot be omitted.
7. Pay attention to this situation
// 文本存储 $this->load->driver('cache',array('adapter'=>'redis','backup'=>'file')); $this->cache->save('key5','xx5',10000); echo $this->cache->get('key5');//xx5
The meaning of this code is to use redis to store it first, and if it is not found, use text storage. You will find that text files are stored in myApplication/cache, and each key will have one text.
Because no error is reported, you may not know where this data exists for a while.
It’s better to use this less often. After all, redis is used for faster speed.
Related recommendations:
How to install and use PHP framework slim##php framework Yaf routing rewriting example code
The above is the detailed content of How to use redis in php framework CodeIgniter. For more information, please follow other related articles on the PHP Chinese website!

Absolute session timeout starts at the time of session creation, while an idle session timeout starts at the time of user's no operation. Absolute session timeout is suitable for scenarios where strict control of the session life cycle is required, such as financial applications; idle session timeout is suitable for applications that want users to keep their session active for a long time, such as social media.

The server session failure can be solved through the following steps: 1. Check the server configuration to ensure that the session is set correctly. 2. Verify client cookies, confirm that the browser supports it and send it correctly. 3. Check session storage services, such as Redis, to ensure that they are running normally. 4. Review the application code to ensure the correct session logic. Through these steps, conversation problems can be effectively diagnosed and repaired and user experience can be improved.

session_start()iscrucialinPHPformanagingusersessions.1)Itinitiatesanewsessionifnoneexists,2)resumesanexistingsession,and3)setsasessioncookieforcontinuityacrossrequests,enablingapplicationslikeuserauthenticationandpersonalizedcontent.

Setting the httponly flag is crucial for session cookies because it can effectively prevent XSS attacks and protect user session information. Specifically, 1) the httponly flag prevents JavaScript from accessing cookies, 2) the flag can be set through setcookies and make_response in PHP and Flask, 3) Although it cannot be prevented from all attacks, it should be part of the overall security policy.

PHPsessionssolvetheproblemofmaintainingstateacrossmultipleHTTPrequestsbystoringdataontheserverandassociatingitwithauniquesessionID.1)Theystoredataserver-side,typicallyinfilesordatabases,anduseasessionIDstoredinacookietoretrievedata.2)Sessionsenhances

PHPsessionscanstorestrings,numbers,arrays,andobjects.1.Strings:textdatalikeusernames.2.Numbers:integersorfloatsforcounters.3.Arrays:listslikeshoppingcarts.4.Objects:complexstructuresthatareserialized.

TostartaPHPsession,usesession_start()atthescript'sbeginning.1)Placeitbeforeanyoutputtosetthesessioncookie.2)Usesessionsforuserdatalikeloginstatusorshoppingcarts.3)RegeneratesessionIDstopreventfixationattacks.4)Considerusingadatabaseforsessionstoragei

Session regeneration refers to generating a new session ID and invalidating the old ID when the user performs sensitive operations in case of session fixed attacks. The implementation steps include: 1. Detect sensitive operations, 2. Generate new session ID, 3. Destroy old session ID, 4. Update user-side session information.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

WebStorm Mac version
Useful JavaScript development tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
