scala实现代理模式

package com.linewell.modeldesgin.proxy

import com.linewell.modeldesgin.dao.AccessDAO

import scala.collection.mutable.ArrayBuffer

/**
* 代理模式
* Created by ctao on 2015/8/29.
*/
/**
* 抽象主题类:查询特质
*/
trait Searcher {
def doSearch(id: String, pass: String, keyword: String): String
}

/**
* 身份验证业务单例对象
*/
object AccessValidator {
/**
* 验证方法
* @param id 查询的id
* @param pass 用户名
* @return 用户是否合法
*/
def validate(id: String, pass: String): Boolean = {
println(s"数据库验证$id 是否为合法用户")
val params = new ArrayBuffer[Any]()
params += id
val result = AccessDAO.checkUser(params)

/**
* 判断result.head获取第一个元素的name和result.head获取第一个元素的pass和传入的id和pass是否一致
* 一致返回true,否则返回false
*/
if (result.head.getOrElse("name", "null") == id && result.head.getOrElse("pass", "null").toString == pass) {
println("登录成功")
true
} else {
println("登录失败")
false
}
}

}

/**
* 日志记录类
*/
object Logger {
/**
* 记录日志
* @param id 登录id
*/
def log(id: String): Unit = {
val params = new ArrayBuffer[Any]()
params += id
val row = AccessDAO.insertLog(params)
if (row > 0) {
println(s"记录$id 到数据库")

} else {
println("出现异常")
}

}
}

/**
* 真实主题类:具体查询类
*/
object RealSearcher extends Searcher {
/**
* 复写查询方法
* @param id 用户id
* @param pass pass
* @param keyword 关键字
* @return 查询内容
*/
override def doSearch(id: String, pass: String, keyword: String): String = {
println(s"用户:$id 使用关键字$keyword 查询商务信息!")
"具体内容"
}
}

/**
* 代理主题类:代理查询类
*/
object ProxySearcher extends Searcher {
/**
* 真实查询对象
*/
private val realSearcher = RealSearcher
/**
* 身份验证对象
*/
private val accessValidator = AccessValidator
/**
* 日志对象
*/
private val logger = Logger

/**
* 复写查询
* @param id 用户id
* @param pass 密码
* @param keyword 关键字
* @return 查询结果
*/
override def doSearch(id: String, pass: String, keyword: String): String = {
/**
* 判断是否登录成功,如果登录成功则记录到数据库中,并执行真实查询类的查询方法
*/
if (validate(id, pass)) {
log(id)
realSearcher.doSearch(id, pass, keyword)
} else {
null
}
}

/**
* 日志方法,使用日志对象的日志方法
* @param id 用户id
*/
def log(id: String): Unit = logger.log(id)

/**
* 身份验证类
* @param id 用户id
* @param pass 密码
* @return 是否验证成功
*/
def validate(id: String, pass: String): Boolean = accessValidator.validate(id, pass)
}


package com.linewell.modeldesgin.dao

import com.linewell.modeldesgin.DBUtil.MySQLDBConn

import scala.collection.mutable.ArrayBuffer

/**
* 代理帐号操作数据库对象
* Created by ctao on 2015/8/29.
*/
object AccessDAO {
/**
* 查询sql
*/
private val sqlSelect = "select name,pass from user where name = ?"

/**
* 查询
* @param params 参数列表
* @return ArrayBuffer
*/
def checkUser(params: ArrayBuffer[Any]) = MySQLDBConn.Result(sqlSelect, params)

/**
* 插入日志列表sql
*/
private val sqlInsert = "insert into log(userid) values(?)"

/**
* 插入操作
* @param params 参数
* @return 受影响行数
*/
def insertLog(params: ArrayBuffer[Any]) = MySQLDBConn.updateRow(sqlInsert, params)


}


package com.linewell.modeldesgin.DBUtil

import java.sql._

import scala.collection.mutable
import scala.collection.mutable.ArrayBuffer

/**
* Mysql数据库连接
* Created by ctao on 2015/8/29.
*/
object MySQLDBConn {
try {
/**
* 加载驱动
*/
classOf[com.mysql.jdbc.Driver]
} catch {
case e: ClassNotFoundException => e.printStackTrace()
}

/**
* 获取数据库连接
* @return 数据库连接
*/
def connection(): Connection = DriverManager.getConnection(DBUtil.url, DBUtil.username, DBUtil.pass)

/**
* 返回查询的结果保存成ArrayBuffer
* @param sql 执行sql语句
* @param params 参数
* @return ArrayBuffer
*/
def Result(sql: String, params: ArrayBuffer[Any]): ArrayBuffer[mutable.HashMap[Any, Any]] = {
var arrayBuffer = new ArrayBuffer[mutable.HashMap[Any, Any]]()
var conn: Connection = null
var prepare: PreparedStatement = null
var rs: ResultSet = null
try {
conn = connection()
prepare = conn.prepareStatement(sql)
var i = 0
if (params != null) {
if (params.nonEmpty) {
for (s <- params) {
prepare.setObject(i + 1, s)
i += 1
}
}
}

rs = prepare.executeQuery()
while (rs.next()) {
val md = rs.getMetaData
val column = md.getColumnCount

var rowData = new mutable.HashMap[Any, Any]()
for (i <- 1 to column) {
rowData.put(md.getColumnName(i), rs.getObject(i))
}
arrayBuffer += rowData
}

} catch {
case sql: SQLException => sql.printStackTrace()
} finally {
closeAll(conn, prepare, rs)
}
arrayBuffer

}

/**
* 更新受影响行数
* @param sql sql语句
* @param params 参数
* @return 受影响行数
*/
def updateRow(sql: String, params: ArrayBuffer[Any]): Int = {
var conn: Connection = null
var prepare: PreparedStatement = null
try {
conn = connection()
prepare = conn.prepareStatement(sql)
var i = 0
if (params != null) {
if (params.nonEmpty) {
for (s <- params) {
prepare.setObject(i + 1, s)
i += 1
}
}
}
return prepare.executeUpdate()
} catch {
case sql: SQLException => sql.printStackTrace()
} finally {
closeAll(conn, prepare, null)
}
-1
}

/**
* 关闭数据库连接
* @param conn 数据库连接
*/
def closeConn(conn: Connection): Unit = {
conn.close()
}

/**
* 关闭resultSet
* @param resultSet resultSet
*/
def closeResultSet(resultSet: ResultSet): Unit = {
resultSet.close()
}

/**
* 关闭preparedStatement
* @param preparedStatement preparedStatement
*/
def closePreparedStatement(preparedStatement: PreparedStatement): Unit = {
preparedStatement.close()
}

/**
* 关闭全部
* @param connection connection
* @param preparedStatement preparedStatement
* @param resultSet resultSet
*/
def closeAll(connection: Connection, preparedStatement: PreparedStatement, resultSet: ResultSet): Unit = {
if (connection != null) {
closeConn(connection)
}
if (preparedStatement != null) {
closePreparedStatement(preparedStatement)
}
if (resultSet != null) {
closeResultSet(resultSet)
}
}


}

package com.linewell.modeldesgin.proxy

/**
* 测试客户端
* Created by ctao on 2015/8/29.
*/
object Client extends App {
val searcher1: Searcher = ProxySearcher
println(searcher1.doSearch("ctt", "12223", "hello"))
val searcher2: Searcher = ProxySearcher
println(searcher2.doSearch("ct", "12334", "helloworld"))

print(searcher1.eq(searcher2))

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Scala实现Flink CDC的示例代码如下所示: ```scala import org.apache.flink.streaming.api.scala.StreamExecutionEnvironment import com.alibaba.ververica.cdc.connectors.mysql.MySQLSource import com.alibaba.ververica.cdc.connectors.mysql.table.StartupOptions import com.alibaba.ververica.cdc.debezium.StringDebeziumDeserializationSchema import org.apache.flink.streaming.api.scala._ object MyFlinkCDC { def main(args: Array[String]): Unit = { val env = StreamExecutionEnvironment.getExecutionEnvironment // 使用MySQLSource创建数据源 // 同时指定StringDebeziumDeserializationSchema,将CDC转换为String类型输出 val sourceFunction = MySQLSource.builder() .hostname("hadoop102") .port(3306) .username("root") .password("123456") .databaseList("test01") .tableList("test01.student") .deserializer(new StringDebeziumDeserializationSchema) .startupOptions(StartupOptions.latest) .build() // 单并行度打印,避免输出乱序 env.addSource(sourceFunction).print.setParallelism(1) env.execute() } } ``` 在pom.xml文件中添加Flink CDC的依赖如下所示: ```xml <dependency> <groupId>com.alibaba.ververica</groupId> <artifactId>flink-connector-mysql-cdc</artifactId> <version>1.1.0</version> </dependency> ``` 这个示例代码使用了Flink CDC连接器来读取MySQL数据源,并将CDC转换为字符串类型输出。同时,通过指定数据库和表名,可以选择性地读取特定的数据。最后,通过设置单个并行度打印,可以避免输出乱序。添加相应的依赖后,你可以在Scala项目中使用这个示例来实现Flink CDC的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [scala 实现flink cdc](https://blog.csdn.net/weixin_43363407/article/details/119456461)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [scala版本的flink CDC](https://blog.csdn.net/weixin_46609492/article/details/123807913)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [jwt:JWT规范的Scala实现](https://download.csdn.net/download/weixin_42134094/18330899)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值