- 【js】js随笔
kiraraLou
javascript前端jsjavascript
JS数组通过数组下标获取数组arr[0]数组长度arr.lengthfor…of循环(ES6)for(elementofiterable){console.log(element);}数组遍历原数据:res=[{id:1,name:‘西安’,address:‘西部’},{id:2,name:‘扬州’,address:‘南部’}]需求一:结果:res=[1,2]代码:varresult=[]res.
- js随笔
sunshineLWZL
validatePhonefunctionvalidatePhone(str){if(!str)returnfalsereturn/^(0|86|17951)?(13[0-9]|15[012356789]|17[0678]|18[0-9]|14[57])[0-9]{8}$/g.test(str)}createAsyncValidatefunctioncreateAsyncValidate(func
- Node.js随笔----CORS解决跨域问题
睡不着还睡不醒
node.js前端javascript
cors是Express的一个第三方中间件,通过安装和配置cors中间件,可以很方便地解决跨域问题使用步骤分为三步:①使用npminstallcors安装中间件②使用constcors=require('cors');导入中间件③在路由之前调用app.use(cors())配置中间件黑马程序员Node.jscors跨域实例:constexpress=require('express');const
- js随笔
Why自给自足
一、两种创建数组的方法1)常见的:vararr=[1,2,3];2)高逼格创建方法:vararr=newArray(3);arr[0]=1;arr[1]=2;arr[2]=3;console.log(arr);二、把数组转换成字符串vararr=[1,2,3];varstr=arr.join('+');//输出为1+2+3;三、怎样根据数组的长度与下标来找数组最后一位数值vari=['1','2'
- JS随笔
MasteRiver
JavaScript中数据类型numberstringbooleanundefinedobjectnull其中基本数据类型为number,stringBoolean,undefined,nullobject为复杂数据类型(广义的对象)算式运算NaN与任何数值运算都是NaN在实现number与number运算的情况下,和java等编译语言不同的地方是:java在int数据进行除法时,会将小数部分自动
- JS随笔(2)
WēnJùnKāng
javascript
1.递归vari=0;functionfn(){console.log(i++);if(i>10){return;}fn();}fn()2.阶乘functionfn(n){if(n==1){return1;}returnn*fn(n-1);}console.log(fn(3));console.log(fn(4));3.斐波那契数列functionfn(n){if(n==1||n==2){retu
- JS随笔(1)
WēnJùnKāng
javascript
1.JS分为三个部分组成,分别是ECMASCRIPT,BOM,DOMECMASCRIPT定义了javascript的语法规范,描述了语言的基本语法和数据类型BOM(BrowserObjectModel)即浏览器对象模型,通过BOM可以操作浏览器窗口,比如:弹出框、控制浏览器跳转、获取分辨率等DOM(DocumentObjectModel)文档对象模型,一套操作页面元素的API,DOM可以把HTML
- js随笔02
叶夏星辰
1.日期的格式转换日期年月日加入"-"string.replace(/^(\d+?)(\d{2})(\d{2})$/,"$1-$2-$3")2.如何绑定一个函数到对象fn.apply(e,[])第二个参数是一个参数数组fn.call(e,arg1,arg2...)apply和call会立即执行fn.bind(e,arg1,arg2...)bind返回的是一个函数,不会立即执行,要执行需要fn.bi
- js随笔一
凡人在世
javascript
获取元素的方法:通过ID获取(getElementById)通过name属性(getElementsByName)通过标签名(getElementsByTagName)通过类名(getElementsByClassName)获取html的方法(document.documentElement)documentElement属性以一个元素对象返回一个文档的文档元素。可以看到一个页面的结构获取body
- 原生js随笔
weixin_30578677
操作系统javascript
JavaScript是一种基于对象和事件驱动的客户端脚本语言组成:ECMAScript---------------标准语法Bom(browserObjectModel)Dom(document)-------浏览器提供的扩充API:applicationprogramminginterface应用程序接口js引入,内部和外部,最好都放到body里的标签前;外部:-----可维护性高,可缓存的;放
- Nodejs随笔(一):Hello World!
are27316
操作系统shell
声明:本人用的是Ubuntu14.04LTS系统。一、Nodejs安装:直接apt-get安装,最简单:sudoapt-getinstallnodejs编译安装sudoapt-getupdatesudoapt-getupgradesudoapt-getinstallbuild_essentialopenssllibssl-devpkg-configwgethttp://nodejs.org/dis
- Vue.js随笔二(新建路由+component+添加样式+变量的显示)
weixin_33804990
创建一个页面:1.首先让我们看一下整个vue.js的目录,如下图所示:2.现在让我们创建一个页面吧:2-1首先你需要新建路由(就和建立一个如何找到项目文件的目录一个意思):进入src/router/index.js修改即可1importVuefrom'vue'2importRouterfrom'vue-router'34//就拿下面这行作比方,下面这行就相当于引入Say这个component5im
- js随笔
覆手为云雨
js
1.varstr=‘sfdsffffffffdd’;判断每个字符出现的次数解析:先把遍历s字符串通过letter变量将字符串中不同项存进对象obj中再通过forin遍历对象varstr='sfdsffffffffdd';letobj={};letletter,key,num;for(leti=0;i-1&&checkString(url.split('?')[1])){url.split('?')
- js随笔
dianfenze8218
参考链接:https://juejin.im/post/5d23e750f265da1b855c7bbehttps://github.com/ly2011/blog/issues/1537ES5/ES6的继承除了写法以外还有什么区别classSuper{}classSubextendsSuper{}constsub=newSub();Sub.__proto__===Super;子类可以直接通过pr
- Vue.js随笔三(npm init webpack my-project指令安装失败解决方案)
weixin_34354945
如果没有安装淘宝给的镜像就先安装一下,指令如下,对!就是如此简单:npminstall-gcnpm-registry=https://registry.npm.taobao.org首先输入npminitwebpackmy-working,一定不要激动,这里不是一路回车哦,当到达红色区域那个问题时你要选择No,Iwillhandlethatmyself然后就可以回车了,这样之后最后键入如下两个指令即
- Node.js + Express 4+angularjs随笔小记,不供参考
weixin_33831196
为什么80%的码农都做不了架构师?>>>1.安装expressnpminstallexpress-gnpminstallexpress-generator-g2.创建express项目express-eangular_cccdangular_cc&&npminstall3.启动程序npmstart即可看到view/index.ejs页面内容4.与angularjs结合,修改ejs为html显示创建
- angularJS随笔
weixin_30496431
1.作用域基于作用域的事件传播作用域可以像DOM节点一样,进行事件的传播。主要是有两个方法:broadcasted:从父级作用域广播至子级scopeemitted:从子级作用域往上发射到父级作用域Root作用域MyEventcount:{{count}}$emit('MyEvent')$broadcast('MyEvent')Middle作用域MyEventcount:{{count}}Leaf作
- angularjs随笔 -- angularjs简单使用
快乐的糖糖
angularjs
angularjs简单使用1.angularjs背景2.angularjs优势3.最简单的angularjs框架4.常用指令5.路由机制5.1angular-route5.2angular-ui-router6.服务的注册及使用7.自定义指令注册与使用8.一个完整的angularjs案例1.angularjs背景angularjs框架在2019年及之前与Vue、react并称前端最火的三大主流框架
- angularjs随笔 -- 项目中使用 angularjs 踩过的坑
快乐的糖糖
angularjs
项目中使用angularjs踩过的坑1.双向数据绑定不生效?2.设置的定时器,清不掉!!!3.$on事件多次触发?4.总结框架虽好用,但是也会有各种坑,本人使用了angularjs框架两年多的时间,碰到过很多的问题,以下针对典型问题做分析共享:1.双向数据绑定不生效?问题背景:我明明采用了ng-model进行了数据绑定,js逻辑修改了数据,但是页面就是没有刷新,甚至于我在控制台进行断点调试,发现数
- angularjs随笔 -- angularjs使用自定义指令封装下拉框
快乐的糖糖
angularjs
angularjs使用自定义指令封装下拉框1.效果图如下:2.代码如下:3.封装组件总结:angularjs核心部分在自定义指令的使用,本文以封装下拉框为例做介绍,其他组件封装方法类似,有需要的请自行扩展。1.效果图如下:2.代码如下:Document*{margin:0;padding:0;}ul{list-style:none;}::-webkit-scrollbar{width:8px;he
- js随笔记(一)
秋枫残红
isFinite()判断一个数是否超出number范围,超出返回falseNaN,任何数除以非数值类型,都将返回NaN可当做false使用NaN!=NaNisNaN(),该函数帮助我们判断一个变量是否为可以被转化为数值,若不能返回true,boolean可以被转化为数字null为空的字符串指针,故typeofnull返回object,且null==undfinedtypeof关键字返回值"unde
- 初始vuejs随笔
tsuyoii
前端vuevuevue.js
下一篇:初识vuejs随笔(二)(注:本篇只是学习过程中的随笔,知识点尚且较为零散,占坑填)vuejs简介vuejs是一种渐进式框架;渐进式指:在开发项目时,可以进行嵌套使用,例如可以同时存在vue框架和其他框架,就像演变过程,可以保留一些原来的东西,慢慢过渡到新东西,此为渐进式。列表展示:v-for计算器案例:事件监听–>click事件–>methodsvue全家桶,可包括(core+vue-r
- Video.js随笔记
不进腾讯不改名
下载与介绍Video.js是一款web视频播放器,支持html5和flash两种播放方式。更有自定义皮肤,插件,组件,语言还有丰富的选项配置。官网下载地址:https://videojs.com/getting-started/GitHub下载地址:https://github.com/videojs/video.js入门使用引入video.js和video-js.css使用下面的video标签,
- rxjs随笔2-理解操作符
黄岩脚
typescriptangular6reactivex
看rxjs文档的时候,我总是被merge->mergeAll->mergeMap等类似的名称的操作符困扰。一直在思考这里面是不是有什么联系,结论:merge与(mergeAll&&mergeMao)没有任何关系,就像这篇文章和白洁没有任何关系一样。注:果然理解错误了,merge与mergeAll的作用是类似的,不用使用方式不一样。他们都是将接受到的observable进行订阅,不过merge的使用
- rxjs随笔1--rxjs能做什么
黄岩脚
rxjstypescriptjavascript
首先我们要弄懂这几个问题:1.rxjs是什么2.rxjs能做什么3.已经有了promise的情况下为什么还需要rxjs4.rxjs的使用方法如果这些问题都直接去网上搜然后贴上链接,感觉我这篇文章就没什么写的必要了。当然了资料已经非常多了,确实不需要我再为大家写一点所谓有帮助的文章了。那么为什么还要写呢,写这个是为了自己,为了自己能够更好的理解rxjs,与大家无关,也与白洁无关。1.rxjs是什么R
- js随笔
潇湘待雨
参考链接:https://juejin.im/post/5d23e750f265da1b855c7bbehttps://github.com/ly2011/blog/issues/1537ES5/ES6的继承除了写法以外还有什么区别classSuper{}classSubextendsSuper{}constsub=newSub();Sub.__proto__===Super;子类可以直接通过pr
- Vue.js随笔四(方法的声明和使用)
迷途纸鸢
1.首先你需要新建路由,这个就不多说了2.然后在你的新的.vue里面需要如下所示的添加methods:{方法},然后按钮的里面你会看到v-on:click,这就是点击这个按钮会触发的动作,这个就是触发methods里的highlight函数,当然v-on:click也可以写成@click这两个是一样的1234567{{message}}89真的吗10111213varapp=newVue({14e
- Vue.js随笔三(npm init webpack my-project指令安装失败解决方案)
迷途纸鸢
如果没有安装淘宝给的镜像就先安装一下,指令如下,对!就是如此简单:npminstall-gcnpm-registry=https://registry.npm.taobao.org首先输入npminitwebpackmy-working,一定不要激动,这里不是一路回车哦,当到达红色区域那个问题时你要选择No,Iwillhandlethatmyself然后就可以回车了,这样之后最后键入如下两个指令即
- Vue.js随笔二(新建路由+component+添加样式+变量的显示)
迷途纸鸢
创建一个页面:1.首先让我们看一下整个vue.js的目录,如下图所示:2.现在让我们创建一个页面吧:2-1首先你需要新建路由(就和建立一个如何找到项目文件的目录一个意思):进入src/router/index.js修改即可1importVuefrom'vue'2importRouterfrom'vue-router'34//就拿下面这行作比方,下面这行就相当于引入Say这个component5im
- Vue.js随笔一(Webpack + Vue.js开发准备,含VNM、NPM、Node、Webpack等相关工具)
迷途纸鸢
想入门工具是必须的,这一章将向大家带来vue.js相关的程序安装步骤。①首先你需要有一个NVM(一个非常好用的Node版本管理器):1.NVM下载地址:https://github.com/coreybutler/nvm-windows/releases下载nvm-setup.zip即可2.安装过程(除了第二个需要手动选个安装目录其他的直接下一步就ok):3.此时你需要检查环境变量是否自动配置:打
- 开发者关心的那些事
圣子足道
ios游戏编程apple支付
我要在app里添加IAP,必须要注册自己的产品标识符(product identifiers)。产品标识符是什么?
产品标识符(Product Identifiers)是一串字符串,它用来识别你在应用内贩卖的每件商品。App Store用产品标识符来检索产品信息,标识符只能包含大小写字母(A-Z)、数字(0-9)、下划线(-)、以及圆点(.)。你可以任意排列这些元素,但我们建议你创建标识符时使用
- 负载均衡器技术Nginx和F5的优缺点对比
bijian1013
nginxF5
对于数据流量过大的网络中,往往单一设备无法承担,需要多台设备进行数据分流,而负载均衡器就是用来将数据分流到多台设备的一个转发器。
目前有许多不同的负载均衡技术用以满足不同的应用需求,如软/硬件负载均衡、本地/全局负载均衡、更高
- LeetCode[Math] - #9 Palindrome Number
Cwind
javaAlgorithm题解LeetCodeMath
原题链接:#9 Palindrome Number
要求:
判断一个整数是否是回文数,不要使用额外的存储空间
难度:简单
分析:
题目限制不允许使用额外的存储空间应指不允许使用O(n)的内存空间,O(1)的内存用于存储中间结果是可以接受的。于是考虑将该整型数反转,然后与原数字进行比较。
注:没有看到有关负数是否可以是回文数的明确结论,例如
- 画图板的基本实现
15700786134
画图板
要实现画图板的基本功能,除了在qq登陆界面中用到的组件和方法外,还需要添加鼠标监听器,和接口实现。
首先,需要显示一个JFrame界面:
public class DrameFrame extends JFrame { //显示
- linux的ps命令
被触发
linux
Linux中的ps命令是Process Status的缩写。ps命令用来列出系统中当前运行的那些进程。ps命令列出的是当前那些进程的快照,就是执行ps命令的那个时刻的那些进程,如果想要动态的显示进程信息,就可以使用top命令。
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而 ps 命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以确定有哪些进程正在运行
- Android 音乐播放器 下一曲 连续跳几首歌
肆无忌惮_
android
最近在写安卓音乐播放器的时候遇到个问题。在MediaPlayer播放结束时会回调
player.setOnCompletionListener(new OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mp) {
mp.reset();
Log.i("H
- java导出txt文件的例子
知了ing
javaservlet
代码很简单就一个servlet,如下:
package com.eastcom.servlet;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.URLEncoder;
import java.sql.Connection;
import java.sql.Resu
- Scala stack试玩, 提高第三方依赖下载速度
矮蛋蛋
scalasbt
原文地址:
http://segmentfault.com/a/1190000002894524
sbt下载速度实在是惨不忍睹, 需要做些配置优化
下载typesafe离线包, 保存为ivy本地库
wget http://downloads.typesafe.com/typesafe-activator/1.3.4/typesafe-activator-1.3.4.zip
解压r
- phantomjs安装(linux,附带环境变量设置) ,以及casperjs安装。
alleni123
linuxspider
1. 首先从官网
http://phantomjs.org/下载phantomjs压缩包,解压缩到/root/phantomjs文件夹。
2. 安装依赖
sudo yum install fontconfig freetype libfreetype.so.6 libfontconfig.so.1 libstdc++.so.6
3. 配置环境变量
vi /etc/profil
- JAVA IO FileInputStream和FileOutputStream,字节流的打包输出
百合不是茶
java核心思想JAVA IO操作字节流
在程序设计语言中,数据的保存是基本,如果某程序语言不能保存数据那么该语言是不可能存在的,JAVA是当今最流行的面向对象设计语言之一,在保存数据中也有自己独特的一面,字节流和字符流
1,字节流是由字节构成的,字符流是由字符构成的 字节流和字符流都是继承的InputStream和OutPutStream ,java中两种最基本的就是字节流和字符流
类 FileInputStream
- Spring基础实例(依赖注入和控制反转)
bijian1013
spring
前提条件:在http://www.springsource.org/download网站上下载Spring框架,并将spring.jar、log4j-1.2.15.jar、commons-logging.jar加载至工程1.武器接口
package com.bijian.spring.base3;
public interface Weapon {
void kil
- HR看重的十大技能
bijian1013
提升能力HR成长
一个人掌握何种技能取决于他的兴趣、能力和聪明程度,也取决于他所能支配的资源以及制定的事业目标,拥有过硬技能的人有更多的工作机会。但是,由于经济发展前景不确定,掌握对你的事业有所帮助的技能显得尤为重要。以下是最受雇主欢迎的十种技能。 一、解决问题的能力 每天,我们都要在生活和工作中解决一些综合性的问题。那些能够发现问题、解决问题并迅速作出有效决
- 【Thrift一】Thrift编译安装
bit1129
thrift
什么是Thrift
The Apache Thrift software framework, for scalable cross-language services development, combines a software stack with a code generation engine to build services that work efficiently and s
- 【Avro三】Hadoop MapReduce读写Avro文件
bit1129
mapreduce
Avro是Doug Cutting(此人绝对是神一般的存在)牵头开发的。 开发之初就是围绕着完善Hadoop生态系统的数据处理而开展的(使用Avro作为Hadoop MapReduce需要处理数据序列化和反序列化的场景),因此Hadoop MapReduce集成Avro也就是自然而然的事情。
这个例子是一个简单的Hadoop MapReduce读取Avro格式的源文件进行计数统计,然后将计算结果
- nginx定制500,502,503,504页面
ronin47
nginx 错误显示
server {
listen 80;
error_page 500/500.html;
error_page 502/502.html;
error_page 503/503.html;
error_page 504/504.html;
location /test {return502;}}
配置很简单,和配
- java-1.二叉查找树转为双向链表
bylijinnan
二叉查找树
import java.util.ArrayList;
import java.util.List;
public class BSTreeToLinkedList {
/*
把二元查找树转变成排序的双向链表
题目:
输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。
要求不能创建任何新的结点,只调整指针的指向。
10
/ \
6 14
/ \
- Netty源码学习-HTTP-tunnel
bylijinnan
javanetty
Netty关于HTTP tunnel的说明:
http://docs.jboss.org/netty/3.2/api/org/jboss/netty/channel/socket/http/package-summary.html#package_description
这个说明有点太简略了
一个完整的例子在这里:
https://github.com/bylijinnan
- JSONUtil.serialize(map)和JSON.toJSONString(map)的区别
coder_xpf
jqueryjsonmapval()
JSONUtil.serialize(map)和JSON.toJSONString(map)的区别
数据库查询出来的map有一个字段为空
通过System.out.println()输出 JSONUtil.serialize(map): {"one":"1","two":"nul
- Hibernate缓存总结
cuishikuan
开源sshjavawebhibernate缓存三大框架
一、为什么要用Hibernate缓存?
Hibernate是一个持久层框架,经常访问物理数据库。
为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能。
缓存内的数据是对物理数据源中的数据的复制,应用程序在运行时从缓存读写数据,在特定的时刻或事件会同步缓存和物理数据源的数据。
二、Hibernate缓存原理是怎样的?
Hibernate缓存包括两大类:Hib
- CentOs6
dalan_123
centos
首先su - 切换到root下面1、首先要先安装GCC GCC-C++ Openssl等以来模块:yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel2、再安装ncurses模块yum -y install ncurses-develyum install ncurses-devel3、下载Erang
- 10款用 jquery 实现滚动条至页面底端自动加载数据效果
dcj3sjt126com
JavaScript
无限滚动自动翻页可以说是web2.0时代的一项堪称伟大的技术,它让我们在浏览页面的时候只需要把滚动条拉到网页底部就能自动显示下一页的结果,改变了一直以来只能通过点击下一页来翻页这种常规做法。
无限滚动自动翻页技术的鼻祖是微博的先驱:推特(twitter),后来必应图片搜索、谷歌图片搜索、google reader、箱包批发网等纷纷抄袭了这一项技术,于是靠滚动浏览器滚动条
- ImageButton去边框&Button或者ImageButton的背景透明
dcj3sjt126com
imagebutton
在ImageButton中载入图片后,很多人会觉得有图片周围的白边会影响到美观,其实解决这个问题有两种方法
一种方法是将ImageButton的背景改为所需要的图片。如:android:background="@drawable/XXX"
第二种方法就是将ImageButton背景改为透明,这个方法更常用
在XML里;
<ImageBut
- JSP之c:foreach
eksliang
jspforearch
原文出自:http://www.cnblogs.com/draem0507/archive/2012/09/24/2699745.html
<c:forEach>标签用于通用数据循环,它有以下属性 属 性 描 述 是否必须 缺省值 items 进行循环的项目 否 无 begin 开始条件 否 0 end 结束条件 否 集合中的最后一个项目 step 步长 否 1
- Android实现主动连接蓝牙耳机
gqdy365
android
在Android程序中可以实现自动扫描蓝牙、配对蓝牙、建立数据通道。蓝牙分不同类型,这篇文字只讨论如何与蓝牙耳机连接。
大致可以分三步:
一、扫描蓝牙设备:
1、注册并监听广播:
BluetoothAdapter.ACTION_DISCOVERY_STARTED
BluetoothDevice.ACTION_FOUND
BluetoothAdapter.ACTION_DIS
- android学习轨迹之四:org.json.JSONException: No value for
hyz301
json
org.json.JSONException: No value for items
在JSON解析中会遇到一种错误,很常见的错误
06-21 12:19:08.714 2098-2127/com.jikexueyuan.secret I/System.out﹕ Result:{"status":1,"page":1,&
- 干货分享:从零开始学编程 系列汇总
justjavac
编程
程序员总爱重新发明轮子,于是做了要给轮子汇总。
从零开始写个编译器吧系列 (知乎专栏)
从零开始写一个简单的操作系统 (伯乐在线)
从零开始写JavaScript框架 (图灵社区)
从零开始写jQuery框架 (蓝色理想 )
从零开始nodejs系列文章 (粉丝日志)
从零开始编写网络游戏 
- jquery-autocomplete 使用手册
macroli
jqueryAjax脚本
jquery-autocomplete学习
一、用前必备
官方网站:http://bassistance.de/jquery-plugins/jquery-plugin-autocomplete/
当前版本:1.1
需要JQuery版本:1.2.6
二、使用
<script src="./jquery-1.3.2.js" type="text/ja
- PLSQL-Developer或者Navicat等工具连接远程oracle数据库的详细配置以及数据库编码的修改
超声波
oracleplsql
在服务器上将Oracle安装好之后接下来要做的就是通过本地机器来远程连接服务器端的oracle数据库,常用的客户端连接工具就是PLSQL-Developer或者Navicat这些工具了。刚开始也是各种报错,什么TNS:no listener;TNS:lost connection;TNS:target hosts...花了一天的时间终于让PLSQL-Developer和Navicat等这些客户
- 数据仓库数据模型之:极限存储--历史拉链表
superlxw1234
极限存储数据仓库数据模型拉链历史表
在数据仓库的数据模型设计过程中,经常会遇到这样的需求:
1. 数据量比较大; 2. 表中的部分字段会被update,如用户的地址,产品的描述信息,订单的状态等等; 3. 需要查看某一个时间点或者时间段的历史快照信息,比如,查看某一个订单在历史某一个时间点的状态, 比如,查看某一个用户在过去某一段时间内,更新过几次等等; 4. 变化的比例和频率不是很大,比如,总共有10
- 10点睛Spring MVC4.1-全局异常处理
wiselyman
spring mvc
10.1 全局异常处理
使用@ControllerAdvice注解来实现全局异常处理;
使用@ControllerAdvice的属性缩小处理范围
10.2 演示
演示控制器
package com.wisely.web;
import org.springframework.stereotype.Controller;
import org.spring