- MySQL 分布式架构:方案、工具与最佳实践
笑远
mysql分布式架构
MySQL分布式架构:方案、工具与最佳实践在现代企业应用中,随着数据量和用户规模的不断增长,单一的数据库实例往往难以满足高可用性、高性能和可扩展性的需求。这促使企业转向分布式MySQL架构,通过多节点、多实例的方式提升数据库系统的整体性能和可靠性。本文将深入探讨MySQL分布式架构的各种方案、常用工具、实现方法及最佳实践。目录1.分布式MySQL概述2.分布式MySQL架构方案2.1主从复制(Ma
- C# Linq中的Select和SelectMany
C#中Linq的select语句很好理解,因为这个select类似于sql语句中的select——筛选出感兴趣的字段,但是SelectMany就不好理解了,本文主要讲解一下SelectMany,顺便和Select对比。目录1.SelectMany的官方定义2.例子3.Select和SelectMany的对比4.SelectMany的扩展1.SelectMany的官方定义官方定义很简单,就是一句话:
- Oracle 中的 JOB
Oracle中的JOB是一种用于自动化执行特定任务的机制,它允许你在指定的时间间隔或特定时间点执行SQL语句或PL/SQL块。以下是关于OracleJOB的详细讲解:1.JOB的基本概念OracleJOB是数据库中调度任务的一种方式,类似于操作系统的定时任务(如Linux的cron或Windows的任务计划程序)。通过JOB,你可以:在指定时间点执行一次性任务。按固定间隔(如每天、每周)重复执行任
- MySQL 常见面试问题总结
nlog3n
Java学习mysql面试数据库java
MySQLMySQL基础概念1.什么是MySQL?它有哪些特点?2.MySQL中的存储引擎有哪些?它们有什么区别?3.InnoDB和MyISAM的主要区别是什么?4.什么是事务?MySQL如何支持事务?ACID原则详解1.Atomicity(原子性)2.Consistency(一致性)3.Isolation(隔离性)4.Durability(持久性)MySQL数据库设计1.什么是主键、外键和索引?
- SpringBoot +Vue3前后端分离项目入门基础实例五
没刮胡子
软件开发技术实战专栏springboot后端java
项目说明项项目名称使用框架说明后端项目springboot_vue_element_demoSpringBoot+MyBatis-plus+MySQL完成基本的增删改查操作API前端项目vue-projectVue3+ElementUIplus+axios界面展示,调用后端API项目文档目录SpringBoot+Vue3前后端分离项目入门基础实例一SpringBoot+Vue3前后端分离项目入门基
- 用springboot+vue+mybatis写一个前后端分离的后台管理系统
13572025090
mybatisspringbootvue.jsjava后端
在写一个前后端分离的后台管理系统时,您可以使用SpringBoot作为后端框架,Vue.js作为前端框架,MyBatis作为数据访问框架。首先,您需要在SpringBoot中配置MyBatis,连接到数据库并编写相应的SQL语句。然后,您可以编写后端控制器来处理HTTP请求,并使用MyBatis执行数据库操作。在前端部分,您可以使用Vue.js构建用户界面,并使用Axios等库与后端进行交互。当用
- MyBatis初识:为什么选择它?
双力臂404
mybatis基础mybatis开发语言
前言在Java持久层框架的江湖中,MyBatis像一位特立独行的侠客——它既不像JDBC那样需要开发者赤手空拳打天下,也不似Hibernate般用ORM大法将SQL完全封装。这种"中间派"的定位,恰恰解决了开发者在两个极端之间的长期困扰。JDBC的"三座大山"//典型JDBC代码片段Connectionconn=null;PreparedStatementps=null;ResultSetrs=n
- 成功解决运行:Django框架提示:no such table: django_session
懂搬砖
Python小白成长记常见问题解决原力计划djangosqlitepython
文章目录前言1.检查数据库配置2.运行数据库迁移命令3.检查数据库权限4.手动删除数据库文件(仅适用于SQLite)5.检查中间件配置前言当在运行Django框架时出现nosuchtable:django_session错误,这通常意味着Django的数据库表还没有正确创建,特别是django_session表缺失。django_session表用于存储会话数据,Django在处理用户会话时会使用
- MySQL允许root用户远程连接
注意:在实际生产环境中,允许root用户从任意主机(‘%’)连接存在安全风险,建议使用强密码并限制访问IP,或者创建具有必要权限的单独用户用于远程连接。MySQL配置远程连接指南1.登录MySQL服务器mysql-uroot-p#输入root密码后进入MySQL命令行2.切换到mysql系统数据库USEmysql;3.修改root用户访问权限UPDATEuserSEThost='%'WHEREus
- 绕过SQL注入监测的技术
绕过SQL注入监测的技术SQL注入监测通常通过WAF(Web应用防火墙)、IDS/IPS或应用层检测机制实现:1.编码混淆技术十六进制编码:SELECT*FROMusersWHEREid=0x31OR1=1URL编码:id=1%20OR%201%3D1Unicode编码:id=1+OR+1=1→id=1+%u004F%u0052+%u0031%u003D%u00312.注释混淆内联注释(MySQL
- Web安全测试详解
点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快随着互联网时代的蓬勃发展,基于Web环境下的应用系统、应用软件也得到了越来越广泛的使用。目前,很多企业的业务发展都依赖于互联网,比如,网上银行、网络购物、网络游戏等。但,由于很多恶意攻击者想通过截获他人信息去谋取利益,因此,会对Web服务器进行攻击。攻击的方式也非常多,常见的有SQL注入、跨站脚本攻击、跨站请求伪造、缓存区溢出等。由此,我
- Python 爬虫实战:微博话题讨论数趋势爬取与分析全流程
西攻城狮北
python爬虫开发语言
1.项目背景与目标微博话题(#话题#)是社交媒体舆情监测、品牌营销、热点追踪的重要数据源。本实战要完成以下目标:爬取指定话题在7天内的讨论数、阅读量、热搜排名等关键指标。将数据存入MySQL,并每日增量更新。用Pandas+Matplotlib绘制趋势图,直观呈现热度变化。基于SnowNLP做情感倾向分析,输出正面/负面占比。生成一份可分享的HTML可视化报告。2.环境搭建与依赖2.1安装核心库p
- MySQL数据库----DML语句
目录DML-介绍SQL-DML-添加数据SQL-DML-修改数据SQL-DML-删除数据DML-介绍DML英文全称是DataManipulationLanguage(数据操作语言),用来对数据库中表的数据记录进行增删改操作。添加数据(INSERT)修改数据(UPDATE)删除数据(DELETE)SQL-DML-添加数据给指定字段添加数据:INSERTINTO表名(字段1,字段2,…)VALUES(
- QSqlDatabasePrivate::database: unable to open database: “[Microsoft][ODBC SQL Server Driver][DBNETLI
道亦无名
数据库入门数据库microsoft
这个错误提示表明程序无法连接到SQLServer数据库,常见原因和解决方案如下:连接参数错误确认服务器名称、端口、数据库名是否正确示例连接字符串格式:DRIVER={SQLServer};SERVER=服务器地址;DATABASE=数据库名;UID=用户名;PWD=密码网络连接问题检查SQLServer服务是否正在运行确认服务器IP和端口可访问(默认TCP端口1433)检查防火墙是否允许数据库端口
- docker windows 安装mysql:8.0.23
kobe_OKOK_
dockerwindowsmysql
dockerwindows安装mysql拉取镜像dockerpullmysql:8.0.23检查dockerimages创建容器dockerrun-p3306:3306--namemysql-vE:/docker_data_map/mysql/mysql-files:/var/lib/mysql-files-vE:/docker_data_map/mysql/conf:/etc/mysql-vE:
- Linux 宝塔mysql莫名其妙数据库不见了恢复数据库
起因:宝塔安装的mysql线上运行突然表包括库都不见了,想办法恢复数据库登陆mysqlcd/www/server/mysql/binmysql-uroot-p查看binlog日志是否打开showvariableslike'log_%';log_bin如果为ON则为开启状态,如果开启了才可以进行下一步操作查看下binlog日志列表binlog日志文件目录在/www/server/data目录下sho
- Spring Boot 集成 HikariCP 完整示例教程
SpringBoot集成HikariCP完整示例教程适用版本:SpringBoot3.x,HikariCP5.x|语言:Java17+|数据库:MySQL8.0项目概述本示例演示如何在SpringBoot项目中集成和优化HikariCP连接池,包含完整的配置、使用、监控和最佳实践。1.项目依赖配置1.1Maven依赖(pom.xml)4.0.0com.examplehikaricp-demo1.0
- 【记录】Ubuntu安装Mysql
qq_29750461
ubuntulinux运维
本文记录Ubuntu系统下安装Mysql1查看系统信息lsb_release-a2使用apt下载安装Mysql1打开终端,首先更新你的系统包索引,以确保所有包都是最新的sudoaptupdate2安装mysql服务器sudoaptinstallmysql-server(也可以选择对应的mysql-server版本)3查看mysql状态安装完成后sudosystemctlstartmysql//开启
- 超全数据库优化与调优实战指南,从基础到进阶
半夜鬼刀门
数据库面试mysqlsql
一、引言在数据库应用开发与运维过程中,SQL语句的性能表现直接关乎系统的响应速度、资源利用率以及整体稳定性。随着业务数据量的增长和复杂查询场景的增多,对SQL进行优化与调优变得愈发关键。本文将围绕SQL优化这一主题,从慢SQL治理、执行计划分析、架构优化、代码层面优化、索引优化等多个维度展开详细阐述,结合实际案例与工具使用,为大家呈现一套完整的SQL优化实践体系。二、慢SQL治理(一)慢SQL基础
- c# 在sql server 数据库中批插入数据
StevenChen85
上位机C#数据库数据库c#
C#实现SQLServer批量插入数据的几种高效方法及代码示例:1.SqlBulkCopy类(最高效)usingSystem.Data.SqlClient;publicstaticvoidBulkInsertWithSqlBulkCopy(DataTabledata){stringconnectionString="Server=.;Database=TestDB;IntegratedSecuri
- Mybatis多条件查询设置参数的三种方法
2401_83708850
mybatisjava数据库
1.散装参数(@Param注解)定义:当Mapper接口方法有多个参数时,每个参数单独列出,需要用@Param("参数名")注解来指定参数在SQL中的占位符名称。ListselectByConditon(@Param("status")intstatus,@Param("companyName")StringcompanyName,@Param("brandName")StringbrandNam
- MySQL视图
shilinnull
MySQLmysql数据库
文章目录基本使用创建视图删除视图视图规则和限制视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据变化也会影响到视图。基本使用创建视图createview视图名asselect语句;案例:mysql>createviewmyviewasselectename,dnamefromemp,deptwhereemp.deptno=
- 【MySQL】 内置函数
目录1.时间函数2.字符串函数3.数学函数4.其他函数1.时间函数函数名称描述current_date()当前日期current_time()当前时间current_timestamp()当前时间戳date(datetime)返回datetime参数的日期部分date_add(date,intervald_value_type)在date中添加日期/时间,interval后的数值单位可以是:yea
- MySQL使用C语言连接
shilinnull
MySQLmysql
文章目录版本查看以及编译mysql接口介绍初始化链接数据库下发mysql命令mysql_query获取执行结果mysql_store_result获取结果行数mysql_num_rows获取结果列数mysql_num_fields获取列名mysql_fetch_fields获取结果内容mysql_fetch_row关闭mysql链接mysql_closeC语言操作mysql查看连接数代码样例官网下
- mysql启动报错:Can‘t connect to local MySQL server through socket
五月天的尾巴
数据库mysql报错
文章目录一、报错内容二、解决方法一、报错内容在linux上启动mysql时报错[root@localhostbin]#./mysql-uroot-pEnterpassword:ERROR2002(HY000):Can'tconnecttolocalMySQLserverthroughsocket'/tmp/mysql.sock'(2)执行以上命令后报错,并且也没有找到/tmp/mysql.sock
- datax-web任务执行时脏数据
经DataX智能分析,该任务最可能的错误原因是:com.alibaba.datax.common.exception.DataXException:Code:[DBUtilErrorCode-10],Description:[连接数据库失败.请检查您的账号、密码、数据库名称、IP、Port或者向DBA寻求帮助(注意网络环境).].-具体错误信息为:com.mysql.jdbc.exceptions
- Oreacle(SQL语言基础)
关键词:SQL入门、SQL分类、SQL*Plus、SELECT语句、DML语句、事务控制✅摘要SQL(StructuredQueryLanguage)是关系型数据库的核心操作语言,广泛应用于Oracle、MySQL、PostgreSQL、SQLServer等主流数据库系统中。本文将从SQL的基本分类讲起,详细介绍SELECT查询、DML数据操作语句,并结合SQL工具使用和事务控制机制,每个知识点都
- 终端中MySQL基础必掌握的命令
在数据库管理与开发中,熟练掌握MySQL命令行工具是提升效率的关键。本指南将系统梳理终端环境下MySQL的核心操作命令,涵盖数据库管理、表操作、数据增删改查、用户权限控制等模块,并结合实际示例与常见问题解决方案,帮助构建完整的MySQL终端操作知识体系。一、连接与退出MySQL服务器1.1连接本地数据库通过命令行连接到本地MySQL服务器的基础语法为:mysql-u[用户名]-p示例:mysql-
- 达梦库批量操作重复数据及唯一主键冲突问题解决思路
禛陌
java
背景实时数据需要批量入历史表,频率高,数据量大。无法保障数据重复问题。之前我们一直用MongoDB,解决重复问题可用唯一索引解决,MongoDB在批插操作时,可以跳过批插过程中失败的数据继续插入。本次系统建设用的是达梦库,当前遇到的问题是批插时,一条失败,无法执行整个批插。网上找了一些资料,Mysql有insertignorinto…做为相应的解决方案。达梦库未到类似操作,网上建议用mergein
- 如何用 Spring Boot 轻松集成数据库:JPA 与 MyBatis 实践
zhyoobo
springboot数据库mybatisjava开发语言设计模式
一、持久层技术选型之道1.1ORM框架的哲学分野在Java生态中,JPA与MyBatis代表着两种截然不同的设计理念。JPA(JavaPersistenceAPI)作为规范化的ORM标准,强调面向对象思维与声明式编程,而MyBatis则延续了SQL原生的灵活性与控制力。SpringBoot通过自动配置机制,为两种技术提供了无缝集成方案。据统计,2023年StackOverflow开发者调查显示,J
- ASM系列四 利用Method 组件动态注入方法逻辑
lijingyao8206
字节码技术jvmAOP动态代理ASM
这篇继续结合例子来深入了解下Method组件动态变更方法字节码的实现。通过前面一篇,知道ClassVisitor 的visitMethod()方法可以返回一个MethodVisitor的实例。那么我们也基本可以知道,同ClassVisitor改变类成员一样,MethodVIsistor如果需要改变方法成员,注入逻辑,也可以
- java编程思想 --内部类
百合不是茶
java内部类匿名内部类
内部类;了解外部类 并能与之通信 内部类写出来的代码更加整洁与优雅
1,内部类的创建 内部类是创建在类中的
package com.wj.InsideClass;
/*
* 内部类的创建
*/
public class CreateInsideClass {
public CreateInsideClass(
- web.xml报错
crabdave
web.xml
web.xml报错
The content of element type "web-app" must match "(icon?,display-
name?,description?,distributable?,context-param*,filter*,filter-mapping*,listener*,servlet*,s
- 泛型类的自定义
麦田的设计者
javaandroid泛型
为什么要定义泛型类,当类中要操作的引用数据类型不确定的时候。
采用泛型类,完成扩展。
例如有一个学生类
Student{
Student(){
System.out.println("I'm a student.....");
}
}
有一个老师类
- CSS清除浮动的4中方法
IT独行者
JavaScriptUIcss
清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近。CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受。
1、结尾处加空div标签 clear:both 1 2 3 4
.div
1
{
background
:
#000080
;
border
:
1px
s
- Cygwin使用windows的jdk 配置方法
_wy_
jdkwindowscygwin
1.[vim /etc/profile]
JAVA_HOME="/cgydrive/d/Java/jdk1.6.0_43" (windows下jdk路径为D:\Java\jdk1.6.0_43)
PATH="$JAVA_HOME/bin:${PATH}"
CLAS
- linux下安装maven
无量
mavenlinux安装
Linux下安装maven(转) 1.首先到Maven官网
下载安装文件,目前最新版本为3.0.3,下载文件为
apache-maven-3.0.3-bin.tar.gz,下载可以使用wget命令;
2.进入下载文件夹,找到下载的文件,运行如下命令解压
tar -xvf apache-maven-2.2.1-bin.tar.gz
解压后的文件夹
- tomcat的https 配置,syslog-ng配置
aichenglong
tomcathttp跳转到httpssyslong-ng配置syslog配置
1) tomcat配置https,以及http自动跳转到https的配置
1)TOMCAT_HOME目录下生成密钥(keytool是jdk中的命令)
keytool -genkey -alias tomcat -keyalg RSA -keypass changeit -storepass changeit
- 关于领号活动总结
alafqq
活动
关于某彩票活动的总结
具体需求,每个用户进活动页面,领取一个号码,1000中的一个;
活动要求
1,随机性,一定要有随机性;
2,最少中奖概率,如果注数为3200注,则最多中4注
3,效率问题,(不能每个人来都产生一个随机数,这样效率不高);
4,支持断电(仍然从下一个开始),重启服务;(存数据库有点大材小用,因此不能存放在数据库)
解决方案
1,事先产生随机数1000个,并打
- java数据结构 冒泡排序的遍历与排序
百合不是茶
java
java的冒泡排序是一种简单的排序规则
冒泡排序的原理:
比较两个相邻的数,首先将最大的排在第一个,第二次比较第二个 ,此后一样;
针对所有的元素重复以上的步骤,除了最后一个
例题;将int array[]
- JS检查输入框输入的是否是数字的一种校验方法
bijian1013
js
如下是JS检查输入框输入的是否是数字的一种校验方法:
<form method=post target="_blank">
数字:<input type="text" name=num onkeypress="checkNum(this.form)"><br>
</form>
- Test注解的两个属性:expected和timeout
bijian1013
javaJUnitexpectedtimeout
JUnit4:Test文档中的解释:
The Test annotation supports two optional parameters.
The first, expected, declares that a test method should throw an exception.
If it doesn't throw an exception or if it
- [Gson二]继承关系的POJO的反序列化
bit1129
POJO
父类
package inheritance.test2;
import java.util.Map;
public class Model {
private String field1;
private String field2;
private Map<String, String> infoMap
- 【Spark八十四】Spark零碎知识点记录
bit1129
spark
1. ShuffleMapTask的shuffle数据在什么地方记录到MapOutputTracker中的
ShuffleMapTask的runTask方法负责写数据到shuffle map文件中。当任务执行完成成功,DAGScheduler会收到通知,在DAGScheduler的handleTaskCompletion方法中完成记录到MapOutputTracker中
- WAS各种脚本作用大全
ronin47
WAS 脚本
http://www.ibm.com/developerworks/cn/websphere/library/samples/SampleScripts.html
无意中,在WAS官网上发现的各种脚本作用,感觉很有作用,先与各位分享一下
获取下载
这些示例 jacl 和 Jython 脚本可用于在 WebSphere Application Server 的不同版本中自
- java-12.求 1+2+3+..n不能使用乘除法、 for 、 while 、 if 、 else 、 switch 、 case 等关键字以及条件判断语句
bylijinnan
switch
借鉴网上的思路,用java实现:
public class NoIfWhile {
/**
* @param args
*
* find x=1+2+3+....n
*/
public static void main(String[] args) {
int n=10;
int re=find(n);
System.o
- Netty源码学习-ObjectEncoder和ObjectDecoder
bylijinnan
javanetty
Netty中传递对象的思路很直观:
Netty中数据的传递是基于ChannelBuffer(也就是byte[]);
那把对象序列化为字节流,就可以在Netty中传递对象了
相应的从ChannelBuffer恢复对象,就是反序列化的过程
Netty已经封装好ObjectEncoder和ObjectDecoder
先看ObjectEncoder
ObjectEncoder是往外发送
- spring 定时任务中cronExpression表达式含义
chicony
cronExpression
一个cron表达式有6个必选的元素和一个可选的元素,各个元素之间是以空格分隔的,从左至右,这些元素的含义如下表所示:
代表含义 是否必须 允许的取值范围 &nb
- Nutz配置Jndi
ctrain
JNDI
1、使用JNDI获取指定资源:
var ioc = {
dao : {
type :"org.nutz.dao.impl.NutDao",
args : [ {jndi :"jdbc/dataSource"} ]
}
}
以上方法,仅需要在容器中配置好数据源,注入到NutDao即可.
- 解决 /bin/sh^M: bad interpreter: No such file or directory
daizj
shell
在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory。
分析:这是不同系统编码格式引起的:在windows系统中编辑的.sh文件可能有不可见字符,所以在Linux系统下执行会报以上异常信息。
解决:
1)在windows下转换:
利用一些编辑器如UltraEdit或EditPlus等工具
- [转]for 循环为何可恨?
dcj3sjt126com
程序员读书
Java的闭包(Closure)特征最近成为了一个热门话题。 一些精英正在起草一份议案,要在Java将来的版本中加入闭包特征。 然而,提议中的闭包语法以及语言上的这种扩充受到了众多Java程序员的猛烈抨击。
不久前,出版过数十本编程书籍的大作家Elliotte Rusty Harold发表了对Java中闭包的价值的质疑。 尤其是他问道“for 循环为何可恨?”[http://ju
- Android实用小技巧
dcj3sjt126com
android
1、去掉所有Activity界面的标题栏
修改AndroidManifest.xml 在application 标签中添加android:theme="@android:style/Theme.NoTitleBar"
2、去掉所有Activity界面的TitleBar 和StatusBar
修改AndroidManifes
- Oracle 复习笔记之序列
eksliang
Oracle 序列sequenceOracle sequence
转载请出自出处:http://eksliang.iteye.com/blog/2098859
1.序列的作用
序列是用于生成唯一、连续序号的对象
一般用序列来充当数据库表的主键值
2.创建序列语法如下:
create sequence s_emp
start with 1 --开始值
increment by 1 --増长值
maxval
- 有“品”的程序员
gongmeitao
工作
完美程序员的10种品质
完美程序员的每种品质都有一个范围,这个范围取决于具体的问题和背景。没有能解决所有问题的
完美程序员(至少在我们这个星球上),并且对于特定问题,完美程序员应该具有以下品质:
1. 才智非凡- 能够理解问题、能够用清晰可读的代码翻译并表达想法、善于分析并且逻辑思维能力强
(范围:用简单方式解决复杂问题)
- 使用KeleyiSQLHelper类进行分页查询
hvt
sql.netC#asp.nethovertree
本文适用于sql server单主键表或者视图进行分页查询,支持多字段排序。KeleyiSQLHelper类的最新代码请到http://hovertree.codeplex.com/SourceControl/latest下载整个解决方案源代码查看。或者直接在线查看类的代码:http://hovertree.codeplex.com/SourceControl/latest#HoverTree.D
- SVG 教程 (三)圆形,椭圆,直线
天梯梦
svg
SVG <circle> SVG 圆形 - <circle>
<circle> 标签可用来创建一个圆:
下面是SVG代码:
<svg xmlns="http://www.w3.org/2000/svg" version="1.1">
<circle cx="100" c
- 链表栈
luyulong
java数据结构
public class Node {
private Object object;
private Node next;
public Node() {
this.next = null;
this.object = null;
}
public Object getObject() {
return object;
}
public
- 基础数据结构和算法十:2-3 search tree
sunwinner
Algorithm2-3 search tree
Binary search tree works well for a wide variety of applications, but they have poor worst-case performance. Now we introduce a type of binary search tree where costs are guaranteed to be loga
- spring配置定时任务
stunizhengjia
springtimer
最近因工作的需要,用到了spring的定时任务的功能,觉得spring还是很智能化的,只需要配置一下配置文件就可以了,在此记录一下,以便以后用到:
//------------------------定时任务调用的方法------------------------------
/**
* 存储过程定时器
*/
publi
- ITeye 8月技术图书有奖试读获奖名单公布
ITeye管理员
活动
ITeye携手博文视点举办的8月技术图书有奖试读活动已圆满结束,非常感谢广大用户对本次活动的关注与参与。
8月试读活动回顾:
http://webmaster.iteye.com/blog/2102830
本次技术图书试读活动的优秀奖获奖名单及相应作品如下(优秀文章有很多,但名额有限,没获奖并不代表不优秀):
《跨终端Web》
gleams:http