当前位置: 首页 > news >正文

wordpress自动登录ftp网站seo计划书

wordpress自动登录ftp,网站seo计划书,p2p网站建设制作,网站哪家做得好目录 1、什么是Redis 2、Redis的作用 3、Redis常用的五种基本类型#xff08;重要知识点#xff09; 4、安装redis 4.1、查询镜像文件【省略】 4.2、拉取镜像文件 4.3、启动redis并设置密码 4.3.1、修改redis密码【可以不修改】 4.3.2、删除密码【坚决不推荐】 5、S…目录 1、什么是Redis 2、Redis的作用 3、Redis常用的五种基本类型重要知识点 4、安装redis 4.1、查询镜像文件【省略】 4.2、拉取镜像文件 4.3、启动redis并设置密码 4.3.1、修改redis密码【可以不修改】 4.3.2、删除密码【坚决不推荐】 5、SpringBoot整合 1、在pom.xml文件中添加maven依赖 2、添加redis配置 3、添加redisconfig 4、添加SpringBoot启动类 5、常用方法介绍(重要) 1.redisTemplate 2.ValueOperationsString 3.HashOperationsHash 4.ListOperationsList 5.SetOperationsSet 6.ZSetOperationszSet 6.redis缓存穿透、缓存击穿、缓存雪崩区别和解决方案 1、什么是Redis RedisRemote Dictionary Server 即远程字典服务是一个开源的使用ANSIC语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库并提供多种语言的API。 可以理解成一个大容量的map。 2、Redis的作用 可以做为数据库存储数据也可以用来做缓存、计数器、分布式锁等。实际工作中很少用它做数据库。 3、Redis常用的五种基本类型重要知识点 string字符串数据类型 hash类似于对象map的形式 list表示一种线性数据结构队列或栈 set无序不可重复集合 zset有序不可重复集合 另外还有三种数据类型都不是很常用。Geospatial、Bitmap、Hyperloglog redis可以操作位bit但是工作中几乎不用。 4、安装redis 基于docker的安装 4.1、查询镜像文件【省略】 #可以不操作 docker search redis 4.2、拉取镜像文件 docker pull redis:6.2.6 4.3、启动redis并设置密码 docker run -d --name redis-6379 -p 6379:6379 redis:6.2.6 --requirepass 123456 requirepass设置密码 【工作时】启动redis注意事项 密码一定要设置复杂一点 端口映射redis一定不能用默认端口用默认端口一定会被攻击 4.3.1、修改redis密码【可以不修改】 # 1/进入redis容器 docker exec -it redis-6379 /bin/bash # 2/找到redis-cli可执行文件 cd /usr/local/bin # 3/执行redis-cli redis-cli # 4/查看密码 config get requirepass # 5/授权 auth 密码 # 6/修改密码 config set requirepass 新密码 第一步骤进入redis容器 第二步骤找到redis-cli可执行文件 第三步骤执行redis-cli 第四步骤查看密码显示没有授权 第五步骤授权 第六步骤修改密码最好还是使用123456后面整合的时候容易忘记。 第七步骤退出容器 4.3.2、删除密码【坚决不推荐】 config set requirepass 5、SpringBoot整合 1、在pom.xml文件中添加maven依赖 ?xml version1.0 encodingUTF-8? project xmlnshttp://maven.apache.org/POM/4.0.0xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.jr/groupIdartifactIdredis/artifactIdversion1.0-SNAPSHOT/versionparentgroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-parent/artifactIdversion2.6.13/version/parentpropertiesjava.version1.8/java.versionproject.build.sourceEncodingUTF-8/project.build.sourceEncodingproject.reporting.outputEncodingUTF-8/project.reporting.outputEncodingspring-boot.version2.6.13/spring-boot.versionjwt.version0.7.0/jwt.versionfastjson.version1.2.60/fastjson.version/propertiesdependenciesdependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-test/artifactIdscopecompile/scope/dependencydependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactId/dependency!--json--dependencygroupIdcom.alibaba/groupIdartifactIdfastjson/artifactIdversion${fastjson.version}/versionscopecompile/scope/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId/dependency/dependenciesbuildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactIdconfigurationclassifierexec/classifier/configuration/plugin/plugins/build/project 2、添加redis配置 #host:自身ip spring:redis:host: 192.168.146.128 port: 6379password: 123456 3、添加redisconfig package com.jr.config;import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer;Configuration public class RedisConfig {/*** 配置 RedisTemplateString, Object* 设置了键和值的序列化方式键用字符串序列化值用JSON序列化** return RedisTemplate*/Beanpublic RedisTemplateString, Object redisTemplate(RedisConnectionFactory redisConnectionFactory) {GenericJackson2JsonRedisSerializer valueSerializer new GenericJackson2JsonRedisSerializer();StringRedisSerializer keySerialize new StringRedisSerializer();RedisTemplateString, Object result new RedisTemplate();result.setConnectionFactory(redisConnectionFactory);result.setKeySerializer(keySerialize);result.setValueSerializer(valueSerializer);result.setHashKeySerializer(keySerialize);result.setHashValueSerializer(valueSerializer);return result;}} 4、添加SpringBoot启动类 SpringBootApplication public class SpringBootMain {public static void main(String[] args) {SpringApplication.run(SpringBootMain.class);} } 5、常用方法介绍(重要) 1.redisTemplate redisTemplate.hasKey(key);                //判断是否有key所对应的值有则返回true没有则返回false redisTemplate.opsForValue().get(key);    //有则取出key值所对应的值 redisTemplate.delete(key);                //删除单个key值 redisTemplate.delete(keys);             //其中keys:CollectionK keys redisTemplate.dump(key);                //将当前传入的key值序列化为byte[]类型 redisTemplate.expire(key, timeout, unit);    //设置过期时间 redisTemplate.expireAt(key, date);        //设置过期时间 redisTemplate.keys(pattern);            //查找匹配的key值返回一个Set集合类型 redisTemplate.rename(oldKey, newKey);    //返回传入key所存储的值的类型 redisTemplate.renameIfAbsent(oldKey, newKey);    //如果旧值存在时将旧值改为新值 redisTemplate.randomKey();                //从redis中随机取出一个key redisTemplate.getExpire(key);            //返回当前key所对应的剩余过期时间 redisTemplate.getExpire(key, unit);        //返回剩余过期时间并且指定时间单位 redisTemplate.persist(key);                //将key持久化保存 redisTemplate.move(key, dbIndex);        //将当前数据库的key移动到指定redis中数据库当中 【测试代码】 Slf4j SpringBootTest(classes DemoHelloworldApplication.class) SuppressWarnings(all) public class RedisTest {private static final String KEY test:commonKey;Autowiredprivate RedisTemplateString, Object redisTemplate;Testpublic void testCommon() {testCommon(KEY);}public void testCommon(String key) {boolean hasKey redisTemplate.hasKey(key); //hasKey(key);log.info(hasKey {}, hasKey);boolean delete redisTemplate.delete(key); //delete(key);log.info(delete {}, delete);}public void delete(String key) {boolean delete redisTemplate.delete(key);} } 2.ValueOperationsString ValueOperations opsForValue redisTemplate.opsForValue(); opsForValue.set(key, value);    //设置当前的key以及value值 opsForValue.set(key, value, offset);//用 value 参数覆写给定 key 所储存的字符串值从偏移量 offset 开始 opsForValue.set(key, value, timeout, unit);     //设置当前的key以及value值并且设置过期时间 opsForValue.setBit(key, offset, value);    //将二进制第offset位值变为value opsForValue.setIfAbsent(key, value);//重新设置key对应的值如果存在返回false否则返回true opsForValue.get(key, start, end);    //返回key中字符串的子字符 opsForValue.getAndSet(key, value);    //将旧的key设置为value并且返回旧的key opsForValue.multiGet(keys);            //批量获取值 opsForValue.size(key);                //获取字符串的长度 opsForValue.append(key, value);    //在原有的值基础上新增字符串到末尾 opsForValue.increment(key,double increment);//以增量的方式将double值存储在变量中 opsForValue.increment(key,long  increment);    //通过increment(K key, long delta)方法以增量方式存储long值正值则自增负值则自减   Map valueMap new HashMap();   valueMap.put(valueMap1,map1);   valueMap.put(valueMap2,map2);   valueMap.put(valueMap3,map3);   opsForValue.multiSetIfAbsent(valueMap);     //如果对应的map集合名称不存在则添加否则不做修改 opsForValue.multiSet(valueMap);                //设置map集合到redis 【测试代码】 Slf4j SpringBootTest(classes DemoHelloworldApplication.class) SuppressWarnings(all) public class RedisTest {private static final String KEY test:commonKey;Autowiredprivate RedisTemplateString, Object redisTemplate;/*** - string字符串数据类型*/Testpublic void testString() {String key test:string;String key2 test:increment;String key3 test:object;delete(key);delete(key2);delete(key3);redisTemplate.opsForValue().set(key, zhangsan); // set(key, zhangsan);Object value redisTemplate.opsForValue().get(key); // get(key);log.info(value {}, value);redisTemplate.opsForValue().set(key, lisi);value redisTemplate.opsForValue().get(key);log.info(value {}, value);testCommon(key);boolean hasKey redisTemplate.hasKey(key);log.info(hasKey {}, hasKey);redisTemplate.opsForValue().increment(key2, 10);// increment(key2, 10);计数器value redisTemplate.opsForValue().get(key2);log.info(value {}, value);redisTemplate.opsForValue().increment(key2); // increment(key2); 涨1increment(key210);涨10value redisTemplate.opsForValue().get(key2);log.info(value {}, value);User user new User();user.setName(zhangsan);user.setPassword(123456);redisTemplate.opsForValue().set(key3, user);value redisTemplate.opsForValue().get(key3);log.info(value {}, value);} } 3.HashOperationsHash HashOperations opsForHash redisTemplate.opsForHash(); opsForHash.get(key, field);    //获取变量中的指定map键是否有值,如果存在该map键则获取值没有则返回null opsForHash.entries(key);    //获取变量中的键值对 opsForHash.put(key, hashKey, value);    //新增hashMap值 opsForHash.putAll(key, maps);    //以map集合的形式添加键值对 opsForHash.putIfAbsent(key, hashKey, value);    //仅当hashKey不存在时才设置 opsForHash.delete(key, fields);    //删除一个或者多个hash表字段 opsForHash.hasKey(key, field);    //查看hash表中指定字段是否存在 opsForHash.increment(key, field, long increment);    //给哈希表key中的指定字段的整数值加上增量increment opsForHash.increment(key, field, double increment);    //给哈希表key中的指定字段的整数值加上增量increment opsForHash.keys(key);                //获取所有hash表中字段 opsForHash.values(key);                //获取hash表中存在的所有的值 opsForHash.scan(key, options);        //匹配获取键值对ScanOptions.NONE为获取全部键对 【测试代码】 Slf4j SpringBootTest(classes DemoHelloworldApplication.class) SuppressWarnings(all) public class RedisTest {private static final String KEY test:commonKey;Autowiredprivate RedisTemplateString, Object redisTemplate;/*** - hash类似于对象map的形式*/Testpublic void testHash() {String key test:hash;redisTemplate.opsForHash().put(key, name, zhangsan);redisTemplate.opsForHash().put(key, age, 12);Object name redisTemplate.opsForHash().get(key, name);Object age redisTemplate.opsForHash().get(key, age);log.info(name {}, name);log.info(age {}, age);} } 4.ListOperationsList ListOperations opsForList redisTemplate.opsForList(); opsForList.index(key, index);    //通过索引获取列表中的元素 opsForList.range(key, start, end);    //获取列表指定范围内的元素(start开始位置, 0是开始位置end 结束位置, -1返回所有) opsForList.leftPush(key, value);    //存储在list的头部即添加一个就把它放在最前面的索引处 opsForList.leftPush(key, pivot, value);        //如果pivot处值存在则在pivot前面添加 opsForList.leftPushAll(key, value);        //把多个值存入List中(value可以是多个值也可以是一个Collection value) opsForList.leftPushIfPresent(key, value);    //List存在的时候再加入 opsForList.rightPush(key, value);    //按照先进先出的顺序来添加(value可以是多个值或者是Collection var2) opsForList.rightPushAll(key, value);    //在pivot元素的右边添加值 opsForList.set(key, index, value);        //设置指定索引处元素的值 opsForList.trim(key, start, end);        //将List列表进行剪裁 opsForList.size(key);    //获取当前key的List列表长度   //移除并获取列表中第一个元素(如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止) opsForList.leftPop(key);                 opsForList.leftPop(key, timeout, unit);       //移除并获取列表最后一个元素 opsForList.rightPop(key); opsForList.rightPop(key, timeout, unit);       //从一个队列的右边弹出一个元素并将这个元素放入另一个指定队列的最左边 opsForList.rightPopAndLeftPush(sourceKey, destinationKey);     opsForList.rightPopAndLeftPush(sourceKey, destinationKey, timeout, unit);   //删除集合中值等于value的元素(index0, 删除所有值等于value的元素; index0, 从头部开始删除第一个值等于value的元素; index0, 从尾部开始删除第一个值等于value的元素) opsForList.remove(key, index, value);   【测试代码】 Slf4j SpringBootTest(classes DemoHelloworldApplication.class) SuppressWarnings(all) public class RedisTest {private static final String KEY test:commonKey;Autowiredprivate RedisTemplateString, Object redisTemplate;/*** - list表示一种线性数据结构队列或栈*/Testpublic void testList() {String key test:list;log.info(----------------------- {}, 模拟队列);/*模拟队列*/for (int i 0; i 5; i) {redisTemplate.opsForList().leftPush(key, i);}long listSize redisTemplate.opsForList().size(key);log.info(listSize {}, listSize);for (int i 0; i listSize; i) {log.info(test:list {}, redisTemplate.opsForList().rightPop(key));}listSize redisTemplate.opsForList().size(key);log.info(listSize {}, listSize);log.info(----------------------- {}, 模拟栈);/*模拟栈*/for (int i 0; i 5; i) {redisTemplate.opsForList().leftPush(key, i);}listSize redisTemplate.opsForList().size(key);log.info(listSize {}, listSize);for (int i 0; i listSize; i) {log.info(test:list {}, redisTemplate.opsForList().leftPop(key));}listSize redisTemplate.opsForList().size(key);log.info(listSize {}, listSize);} } 5.SetOperationsSet SetOperations opsForSet redisTemplate.opsForSet(); opsForSet.add(key, values);            //添加元素 opsForSet.remove(key, values);        //移除元素(单个值、多个值) opsForSet.pop(key);                    //删除并且返回一个随机的元素 opsForSet.size(key);                //获取集合的大小 opsForSet.isMember(key, value);        //判断集合是否包含value opsForSet.intersect(key, otherKey);    //获取两个集合的交集(key对应的无序集合与otherKey对应的无序集合求交集) opsForSet.intersect(key, otherKeys);//获取多个集合的交集(Collection var2) opsForSet.intersectAndStore(key, otherKey, destKey);    //key集合与otherKey集合的交集存储到destKey集合中(其中otherKey可以为单个值或者集合) opsForSet.intersectAndStore(key, otherKeys, destKey);    //key集合与多个集合的交集存储到destKey无序集合中 opsForSet.union(key, otherKeys);    //获取两个或者多个集合的并集(otherKeys可以为单个值或者是集合) opsForSet.unionAndStore(key, otherKey, destKey);    //key集合与otherKey集合的并集存储到destKey中(otherKeys可以为单个值或者是集合) opsForSet.difference(key, otherKeys);    //获取两个或者多个集合的差集(otherKeys可以为单个值或者是集合) opsForSet.differenceAndStore(key, otherKey, destKey);    //差集存储到destKey中(otherKeys可以为单个值或者集合) opsForSet.randomMember(key);    //随机获取集合中的一个元素 opsForSet.members(key);            //获取集合中的所有元素 opsForSet.randomMembers(key, count);    //随机获取集合中count个元素 opsForSet.distinctRandomMembers(key, count);    //获取多个key无序集合中的元素去重count表示个数 opsForSet.scan(key, options);    //遍历set类似于Interator(ScanOptions.NONE为显示所有的) 【测试代码】 Slf4j SpringBootTest(classes DemoHelloworldApplication.class) SuppressWarnings(all) public class RedisTest {private static final String KEY test:commonKey;Autowiredprivate RedisTemplateString, Object redisTemplate;/*** - set无序不可重复集合*/Testpublic void testSet() {String key test:set;redisTemplate.opsForSet().add(key, zhangsan, lisi, wangwu, 12, 22, 32, wangwu, 12, 12);long listSize redisTemplate.opsForSet().size(key);log.info(listSize {}, listSize);for (int i 0; i listSize; i) {log.info(test:set {}, redisTemplate.opsForSet().pop(key));}listSize redisTemplate.opsForSet().size(key);log.info(listSize {}, listSize);} } 6.ZSetOperationszSet ZSetOperations提供了一系列方法对有序集合进行操作 ZSetOperations opsForZSet redisTemplate.opsForZSet(); opsForZSet.add(key, value, score);                //添加元素(有序集合是按照元素的score值由小到大进行排列) opsForZSet.remove(key, values);                    //删除对应的value,value可以为多个值 opsForZSet.incrementScore(key, value, delta);    //增加元素的score值并返回增加后的值 opsForZSet.rank(key, value);                    //返回元素在集合的排名,有序集合是按照元素的score值由小到大排列 opsForZSet.reverseRank(key, value);                //返回元素在集合的排名,按元素的score值由大到小排列 opsForZSet.reverseRangeWithScores(key, start,end);    //获取集合中给定区间的元素(start 开始位置end 结束位置, -1查询所有) opsForZSet.reverseRangeByScore(key, min, max);    //按照Score值查询集合中的元素结果从小到大排序 opsForZSet.reverseRangeByScoreWithScores(key, min, max);    //返回值为:SetZSetOperations.TypedTupleV opsForZSet.count(key, min, max);                //根据score值获取集合元素数量 opsForZSet.size(key);                            //获取集合的大小 opsForZSet.zCard(key);                            //获取集合的大小 opsForZSet.score(key, value);                    //获取集合中key、value元素对应的score值 opsForZSet.removeRange(key, start, end);        //移除指定索引位置处的成员 opsForZSet.removeRangeByScore(key, min, max);    //移除指定score范围的集合成员 opsForZSet.unionAndStore(key, otherKey, destKey);//获取key和otherKey的并集并存储在destKey中其中otherKeys可以为单个字符串或者字符串集合 opsForZSet.intersectAndStore(key, otherKey, destKey);    //获取key和otherKey的交集并存储在destKey中其中otherKeys可以为单个字符串或者字符串集合 【测试代码】 Slf4j SpringBootTest(classes DemoHelloworldApplication.class) SuppressWarnings(all) public class RedisTest {private static final String KEY test:commonKey;Autowiredprivate RedisTemplateString, Object redisTemplate;/*** - zset有序不可重复集合*/Testpublic void testZset() {String key test:zset;redisTemplate.opsForZSet().add(key, zhangsan, 12);redisTemplate.opsForZSet().add(key, lisi, 22);redisTemplate.opsForZSet().add(key, wangwu, 32);redisTemplate.opsForZSet().add(key, wangwu1, 121);redisTemplate.opsForZSet().add(key, wangwu2, 122);redisTemplate.opsForZSet().add(key, wangwu3, 123);redisTemplate.opsForZSet().add(key, wangwu4, 124);redisTemplate.opsForZSet().add(key, wangwu5, 125);redisTemplate.opsForZSet().add(key, wangwu6, 126);Long zCard redisTemplate.opsForZSet().zCard(key);//long listSize redisTemplate.opsForZSet().size(key);log.info(zCard {}, zCard);log.info(listSize {}, listSize); // for (int i 0; i listSize; i) { // log.info(test:set {}, redisTemplate.opsForZSet().popMax(key)); // }listSize redisTemplate.opsForZSet().size(key);log.info(listSize {}, listSize);log.info(----------------------- {}, 华丽的分割线);SetObject range redisTemplate.opsForZSet().range(key, 1, 3);for (Object o : range) {log.info(range {}, o);}listSize redisTemplate.opsForZSet().size(key);log.info(listSize {}, listSize);} }6.redis缓存穿透、缓存击穿、缓存雪崩区别和解决方案 https://blog.csdn.net/m0_71240584/article/details/142527527?spm1001.2014.3001.5502
文章转载自:
http://www.morning.bprsd.cn.gov.cn.bprsd.cn
http://www.morning.dtlqc.cn.gov.cn.dtlqc.cn
http://www.morning.qjbxt.cn.gov.cn.qjbxt.cn
http://www.morning.dpdr.cn.gov.cn.dpdr.cn
http://www.morning.jwrcz.cn.gov.cn.jwrcz.cn
http://www.morning.bpwfr.cn.gov.cn.bpwfr.cn
http://www.morning.ntwxt.cn.gov.cn.ntwxt.cn
http://www.morning.bplqh.cn.gov.cn.bplqh.cn
http://www.morning.cwwbm.cn.gov.cn.cwwbm.cn
http://www.morning.playmi.cn.gov.cn.playmi.cn
http://www.morning.cyjjp.cn.gov.cn.cyjjp.cn
http://www.morning.blqsr.cn.gov.cn.blqsr.cn
http://www.morning.hjrjr.cn.gov.cn.hjrjr.cn
http://www.morning.sbczr.cn.gov.cn.sbczr.cn
http://www.morning.dkqbc.cn.gov.cn.dkqbc.cn
http://www.morning.zknjy.cn.gov.cn.zknjy.cn
http://www.morning.zhiheliuxue.com.gov.cn.zhiheliuxue.com
http://www.morning.wtdhm.cn.gov.cn.wtdhm.cn
http://www.morning.mntxalcb.com.gov.cn.mntxalcb.com
http://www.morning.gnbtp.cn.gov.cn.gnbtp.cn
http://www.morning.jppdk.cn.gov.cn.jppdk.cn
http://www.morning.sgfgz.cn.gov.cn.sgfgz.cn
http://www.morning.fynkt.cn.gov.cn.fynkt.cn
http://www.morning.qsy39.cn.gov.cn.qsy39.cn
http://www.morning.zsrjn.cn.gov.cn.zsrjn.cn
http://www.morning.fhqsm.cn.gov.cn.fhqsm.cn
http://www.morning.kqglp.cn.gov.cn.kqglp.cn
http://www.morning.dzgmj.cn.gov.cn.dzgmj.cn
http://www.morning.kbbmj.cn.gov.cn.kbbmj.cn
http://www.morning.ghslr.cn.gov.cn.ghslr.cn
http://www.morning.tsnmt.cn.gov.cn.tsnmt.cn
http://www.morning.thrtt.cn.gov.cn.thrtt.cn
http://www.morning.xstfp.cn.gov.cn.xstfp.cn
http://www.morning.xyjlh.cn.gov.cn.xyjlh.cn
http://www.morning.ppbqz.cn.gov.cn.ppbqz.cn
http://www.morning.btsls.cn.gov.cn.btsls.cn
http://www.morning.pnjsl.cn.gov.cn.pnjsl.cn
http://www.morning.pxmyw.cn.gov.cn.pxmyw.cn
http://www.morning.twfdm.cn.gov.cn.twfdm.cn
http://www.morning.bfjtp.cn.gov.cn.bfjtp.cn
http://www.morning.nqbpz.cn.gov.cn.nqbpz.cn
http://www.morning.prsxj.cn.gov.cn.prsxj.cn
http://www.morning.xysxj.com.gov.cn.xysxj.com
http://www.morning.kwhrq.cn.gov.cn.kwhrq.cn
http://www.morning.cbqqz.cn.gov.cn.cbqqz.cn
http://www.morning.xbhpm.cn.gov.cn.xbhpm.cn
http://www.morning.nslwj.cn.gov.cn.nslwj.cn
http://www.morning.china-cj.com.gov.cn.china-cj.com
http://www.morning.skscy.cn.gov.cn.skscy.cn
http://www.morning.fbpdp.cn.gov.cn.fbpdp.cn
http://www.morning.cczrw.cn.gov.cn.cczrw.cn
http://www.morning.bfjtp.cn.gov.cn.bfjtp.cn
http://www.morning.brlcj.cn.gov.cn.brlcj.cn
http://www.morning.bmnm.cn.gov.cn.bmnm.cn
http://www.morning.wjhpg.cn.gov.cn.wjhpg.cn
http://www.morning.fydsr.cn.gov.cn.fydsr.cn
http://www.morning.rfrnc.cn.gov.cn.rfrnc.cn
http://www.morning.nzsdr.cn.gov.cn.nzsdr.cn
http://www.morning.ho-use.cn.gov.cn.ho-use.cn
http://www.morning.kgrwh.cn.gov.cn.kgrwh.cn
http://www.morning.qgxnw.cn.gov.cn.qgxnw.cn
http://www.morning.jkszt.cn.gov.cn.jkszt.cn
http://www.morning.smspc.cn.gov.cn.smspc.cn
http://www.morning.lbssg.cn.gov.cn.lbssg.cn
http://www.morning.clgbb.cn.gov.cn.clgbb.cn
http://www.morning.xsbhg.cn.gov.cn.xsbhg.cn
http://www.morning.nxdqz.cn.gov.cn.nxdqz.cn
http://www.morning.ubpsa.cn.gov.cn.ubpsa.cn
http://www.morning.dhqzc.cn.gov.cn.dhqzc.cn
http://www.morning.rxnl.cn.gov.cn.rxnl.cn
http://www.morning.xlwpz.cn.gov.cn.xlwpz.cn
http://www.morning.jsrnf.cn.gov.cn.jsrnf.cn
http://www.morning.wqngt.cn.gov.cn.wqngt.cn
http://www.morning.yrcxg.cn.gov.cn.yrcxg.cn
http://www.morning.tqsmg.cn.gov.cn.tqsmg.cn
http://www.morning.fzqfb.cn.gov.cn.fzqfb.cn
http://www.morning.nrfrd.cn.gov.cn.nrfrd.cn
http://www.morning.rpdmj.cn.gov.cn.rpdmj.cn
http://www.morning.skwwj.cn.gov.cn.skwwj.cn
http://www.morning.mqbzk.cn.gov.cn.mqbzk.cn
http://www.tj-hxxt.cn/news/271203.html

相关文章:

  • 网站建设公司安丘市营销网站重要特点是
  • 网站首页title营销渠道策略
  • 浙江省建设网站首页合肥宣传网站
  • 禁止拿我们的网站做宣传高端建盏的价格
  • 网站建设思路梳理知乎网页版
  • 国内网站空间 linux网页设计实训结论
  • 网站谷歌优化怎么做网站开发方向和移动开发方向那个好
  • 高密哪里做网站好桂林临桂区建设局网站
  • 大型网站建设推荐淘宝客单品网站源码
  • 苏州个人网站制作公司中山建站
  • 网站建设衡水做产品推广哪个网站好
  • 烟台网站建设找企汇互联专业国家市场监督管理
  • 盐城哪家专业做网站小程序开发教程文档
  • 如何利用影视网站做cpa定制摄影app和摄影网站的区别
  • php wordpress 目录云巅seo
  • 网站建设销售好5元域名免备案
  • 餐饮网站建设设计ps转页面wordpress插件
  • 现在有哪些网站兼职可以做网站受众群体
  • 温州网站关键词排名重庆品牌网站建设公司排名
  • 网页设计网站建设的基本流程wordpress wp_print_scripts
  • 阿里云服务器ip做网站网站懒加载怎么做
  • 深圳给企业做网站安阳黑道的老大是谁
  • 网站底部广告长春关键词排名公司
  • wordpress移动模块位置seo专业培训班
  • 下陆区建设局网站上海缪斯设计好不好
  • 如何做一个网站设计品牌设计图片
  • 网站开发信息发布网站地图生成
  • 赌钱网站怎么做的厦门建设局叶文语简历
  • wordpress开通多站点好处优秀网页设计作品
  • 女性手表网站重庆网站建站建设平台