Spring boot 项目启动因为@value报错Injection of autowired dependencies failed

Spring boot项目启动时报错——

Injection of autowired dependencies failed

Could not resolve placeholder 'owa.url' in string value "${owa.url}"

图片说明

图片说明

定义的owa.url是在application.properties文件当中,并木有问题

因为@Value注解的原因,

但实际上是自己不小心删掉了pom.xml文件里面的一些内容,

其余的文件没有改动

就是不知道是改了pom.xml文件中的那些信息了,

希望告知是缺少了pom.xml中的哪一部分依赖问题,

麻烦帮忙解决一下,谢谢!

4个回答

实际错误是,在对项目进行——
项目右击→Maven→update project之后修改了配置;
解决方法——
项目右击→Properties→Java Build Path →Source 下
将XXXX/src/main/resource的Excluded改为None

好像原因是每次对Maven项目进行update project之后会将这个重置为All,需要设置为None

Injection of autowired dependencies failed ,自动装配的依赖注入失败,建议检查一下pom文件依赖是否正确添加,然后看一下spring配置文件是否有误

配置文件中,owa.url这个值有问题

pom文件中定义的owa.url值被删掉了,建议查看一下历史版本数据,或者手动添加一个owa.url属性

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
爬虫 根据F12拿到了Form data却得不到数据
[https://exclusions.ustr.gov/s/docket?docketNumber=USTR-2019-0005]( "")这是要爬的网站,我要抓那个表格的数据。 根据F12 我看到的Form data是 ![图片说明](https://img-ask.csdn.net/upload/201911/01/1572575634_265292.png) 他的rep是这样的 ![图片说明](https://img-ask.csdn.net/upload/201911/01/1572575662_770561.png) 然后这是我的部分代码 ![图片说明](https://img-ask.csdn.net/upload/201911/01/1572575681_727700.png) 这是我代码运行的结果 ![图片说明](https://img-ask.csdn.net/upload/201911/01/1572575700_192338.png)、 这是我完整的代码 import json import urllib import gzip from io import BytesIO import ssl ssl._create_default_https_context = ssl._create_unverified_context# 验证证书??不是很懂但是解决了SSL问题 def getHtml(url): headers={'User-Agent': 'User-Agent:Mozilla/5.0', 'Accept': '*/*', 'Accept-Encoding': 'gzip, deflate, br', 'Accept-Language': 'zh-CN,zh;q=0.9', 'Connection': 'keep-alive', 'Content-Length': '1483', 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8', #'Cookie': 'pctrk=13806d4e-9502-4a46-b0a9-2dd0335ae056; renderCtx=%7B%22pageId%22%3A%2261489a7e-6511-4230-b9ed-bab5c8ff93b7%22%2C%22schema%22%3A%22Published%22%2C%22viewType%22%3A%22Published%22%2C%22brandingSetId%22%3A%2211600771-9799-46b6-9913-22cd8f714e32%22%2C%22audienceIds%22%3A%226Aut0000000PB9n%22%7D; oinfo=c3RhdHVzPUFDVElWRSZ0eXBlPTYmb2lkPTAwRHQwMDAwMDAwNFhMQw==; autocomplete=1; sid_Client=0000003KCN200000004XLC; clientSrc=222.68.18.123; inst=APPt; oid=00Dt00000004XLC; sid=00Dt00000004XLC!AQMAQHl3llX9OgfLSZgIaLL.z6gaelF3sYrH.QuZwNF1MIR6MR.k19Tfgn1O9Yd0hdFjMn1XQrgtdNQ6tv4MKhSLxjhTF4ET; __cfduid=d85b901ba5cd527ea8548a447e8f01b5a1572504746', 'Host': 'exclusions.ustr.gov', 'Origin': 'https://exclusions.ustr.gov', 'Referer': 'https://exclusions.ustr.gov/s/docket?docketNumber=USTR-2019-0005', #User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36 'X-SFDC-Request-Id': '11312554500007b083'} data = {'message': '{"actions":[{"id":"68;a","descriptor":"aura://ApexActionController/ACTION$execute","callingDescriptor":"UNKNOWN","params":{"namespace":"","classname":"ustrPublicDocketAuraService","method":"getPageRecords","params":{"selectorJSON":"{\"docketNumber\":\"USTR-2019-0005\",\"filteredBy\":\"\",\"sortedBy\":\"Name\",\"sortedDirection\":\"asc\",\"lastSortedByValue\":null,\"lastRequestNumber\":null,\"startIndex\":50,\"endIndex\":100}"},"cacheable":false,"isContinuation":false}}]}', 'aura.context': '{"mode":"PROD","fwuid":"3uHUkqaEy5o9m3W8DAEYIw","app":"siteforce:communityApp","loaded":{"APPLICATION@markup://siteforce:communityApp":"vc87DBrWuhFjIBDb5BvCxQ"},"dn":[],"globals":{},"uad":false}', 'aura.pageURI': '/s/docket?docketNumber=USTR-2019-0005', 'aura.token': 'undefined'} data = urllib.parse.urlencode(data).encode("utf-8") data1 = urllib.request.Request(url, headers=headers) page = urllib.request.urlopen(data1,data=data) html2 = page.read() buff = BytesIO(html2) f = gzip.GzipFile(fileobj = buff) res = f.read().decode('utf-8') return res url = 'https://exclusions.ustr.gov/s/sfsites/aura?r=8&aura.ApexAction.execute=1' #url = 'https://www.baidu.com' a = getHtml(url) print(a) ``` ``` ``` ```
Mybatis批量添加:报错信息:ORA-00933: SQL 命令未正确结束
Mybatis里面: <insert id="insert" useGeneratedKeys="true" parameterType="java.util.Map"> insert into USER_ROLE_AUT (RU_ID, RU_ROLE_ID, RU_AUT_ID, RU_TIME_INS, RU_USER_INS, RU_TIME_LST, RU_USER_LST, RU_STATUS) select U.* from USER_ROLE_AUT ( <foreach collection="maps" item="item" index="index" separator="union all" > select RU_ID_SEQ.Nextval, #{item.ruRoleId,jdbcType=DECIMAL}, #{item.ruAutId,jdbcType=DECIMAL}, #{item.ruTimeIns,jdbcType=TIMESTAMP}, #{item.ruUserIns,jdbcType=VARCHAR}, #{item.ruTimeLst,jdbcType=TIMESTAMP}, #{item.ruUserLst,jdbcType=VARCHAR}, #{item.ruStatus,jdbcType=CHAR} from USER_ROLE_AUT </foreach> )U </insert> action里面: @RequestMapping("roleAutSave") @ResponseBody public Map roleAutSave(HttpServletRequest request, HttpSession session) throws SystemException { Map<String, Object> rtnmap = null; Map<String, Object> map = new HashMap<String, Object>(); try { String ruAutId = request.getParameter("ruAutId");// 获取到树形菜单选中的节点 System.out.println(ruAutId); String[] adeArrs = ruAutId.split(","); System.out.println(adeArrs); String ruRoleId = request.getParameter("ruRoleId");// 获取选中的角色id String ruUserIns = request.getParameter("ruUserIns");// 获取登录的账号 List<UserRoleAut> ls = new ArrayList<UserRoleAut>(); UserRoleAut ur = null; for (String ade : adeArrs) { ur = new UserRoleAut(); ur.setRuRoleId(new Long(ruRoleId)); ur.setRuAutId(new Long(ade)); ur.setRuUserIns(ruUserIns); ls.add(ur); } map.put("maps", ls); userRoleAutMapper.insert(map);// 保存 userRoleAutMapper.deleteByPrimaryKey(); rtnmap = okMap("roleAut"); } catch (Exception e) { rtnmap = failMap("roleAut"); e.printStackTrace(); } return rtnmap; }
mysql语法问题,哪位能帮我一下,谢谢
SELECT MTAUT_ID,MTAUT_NAME,MTAUT_PARID,MTAUT_INDEX FROM MT005AUT GROUP BY MTAUT_PARID,MTAUT_INDEX DESC 想用group by分组排序 报错,Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'mtiansystem.MT005AUT.MTAUT_ID' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
M y b a t i s批量添加
<insert id="insert" useGeneratedKeys="true" parameterType="java.util.Map"> insert into USER_ROLE_AUT (RU_ID,RU_ROLE_ID, RU_AUT_ID, RU_TIME_INS, RU_USER_INS, RU_TIME_LST, RU_USER_LST, RU_STATUS) select U.* from USER_ROLE_AUT ( <foreach collection="maps" item="item" index="index" separator="union all" > select RU_ID_SEQ.Nextval, #{item.ruRoleId,jdbcType=DECIMAL}, #{item.ruAutId,jdbcType=DECIMAL}, #{item.ruTimeIns,jdbcType=TIMESTAMP}, #{item.ruUserIns,jdbcType=VARCHAR}, #{item.ruTimeLst,jdbcType=TIMESTAMP}, #{item.ruUserLst,jdbcType=VARCHAR}, #{item.ruStatus,jdbcType=DECIMAL} from USER_ROLE_AUT </foreach> )U </insert> 帮忙看看有没有写错
java,request.getParameterValues数据库用哪种set保存数据?
AUT = request.getParameterValues("AUT"); 两个问题,第1个是PreparedStatement里用哪种set保存,比如setString? 第2个问题,mysql数据库里用哪种类型保存这种数组数据更合适?
为什么sql语句有记录,而sqlDataReader.read()的返回值还是false
``` protected void input_sub_Click(object sender, EventArgs e) { string name = db.HtmlToTxt(input_name.Text.Trim()); string pwd = db.HtmlToTxt(input_pwd.Text.Trim()); string ip = System.Web.HttpContext.Current.Request.UserHostAddress; string md5pwd = MD5(pwd).Substring(5); db.open(); string strall = "select sw_UserName,sw_state from sw_manage where sw_UserName='" + name + "' and sw_UserPassWord='" + md5pwd + "'"; SqlDataReader sdr = db.sqlcommand(strall).ExecuteReader(); if (sdr.Read()) { int state = (int)sdr[1]; if (state != 1) { Response.Write("<script>alert('账户未被激活,请与管理员联系!');</script>"); } else { string aut = sdr[0].ToString(); HttpCookie cookie = new HttpCookie("userName", aut); Response.Cookies.Add(cookie); sdr.Close(); string str = "update sw_manage set sw_logintime=GETDATE(),sw_loginIp='" + ip + "' where sw_UserName='" + name + "' and sw_UserPassWord='" + md5pwd + "'"; db.checksql(str); db.close(); Response.Redirect("main.aspx#"); } } else { Response.Write("<script>alert('用户名或密码错误!');</script>"); txtPwdwm.Text = ""; sdr.Close(); db.close(); } } ``` sql语句查询是有记录的,
关于springboot进行安全验证的问题,sec:不起作用???
## 1:我在springboot中添加权限功能 在Html页面上利用themleaf 进行数据显示时不能正常按照应有的权限显示? **代码如下:** pom.xml文件 ``` <dependency> <groupId>org.thymeleaf.extras</groupId> <artifactId>thymeleaf-extras-springsecurity4</artifactId> <version>2.1.3.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> ``` java ``` @EnableWebSecurity public class MySecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { //super.configure(http); //定制请求授权规则 http.authorizeRequests().antMatchers("/").permitAll() .antMatchers("/ghost/**").hasRole("Level1") .antMatchers("/ghost1/**").hasRole("Level2") .antMatchers("/ghost2/**").hasRole("Level3"); //开启登录功能,没有权限就会来到登陆页面 如果登陆错误会重定向到erro 表示登陆失败 http.formLogin(); //开启自动配置的注销功能,注销成功来到首页 http.logout().logoutSuccessUrl("/"); } //自定义认证规则 @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { // super.configure(auth); auth.inMemoryAuthentication().passwordEncoder(new BCryptPasswordEncoder()). withUser("张三") .password(new BCryptPasswordEncoder().encode("123456")) .roles("Level1","Level2") .and() .passwordEncoder(new BCryptPasswordEncoder()) .withUser("李四") .password(new BCryptPasswordEncoder().encode("123456")) .roles("Level2","Level3") .and() .passwordEncoder(new BCryptPasswordEncoder()) .withUser("王五") .password(new BCryptPasswordEncoder().encode("123456")) .roles("Level3"); } } ``` **html 首页显示如下**: ``` <!DOCTYPE html> :action="@{/logout}" method="post"> <input th:type="submit" th:value="注销"> </form> </div> <br> <div sec:aut<html xmlns:th="http://www.thymeleaf.org" xmlns:sec="http://www.thymeleaf.org/thymeleaf-extras-springsecurity4"> <head> <meta charset="UTF-8"> <title>Home</title> </head> <body> <h1 th:align="center">这是主页</h1> <div > <div style="display: inline"> <div sec:authorize="!isAuthenticated()"> 游客您好!<a th:href="@{/login}">请登录</a> </div> <div sec:authorize="isAuthenticated()"> <span sec:authentication="name"></span>,您好!(<span sec:authentication="principal.getAuthorities()"></span>) <form thhorize="hasRole('Level1')"> <h3>会员级别一</h3> <h5><a href="/ghost/1">a1</a></h5> <h5><a href="/ghost/2">a2</a></h5> <h5><a href="/ghost/3">a3</a></h5> </div> <br> <div sec:authorize="hasRole('Level2')"> <h3>会员级别二</h3> <h5><a href="/ghost1/1">b1</a></h5> <h5><a href="/ghost1/2">b2</a></h5> <h5><a href="/ghost1/3">b3</a></h5> </div> <br> <div sec:authorize="hasRole('Level3')"> <h3>会员级别三</h3> <h5><a href="/ghost2/1">c1</a></h5> <h5><a href="/ghost2/2">c2</a></h5> <h5><a href="/ghost2/3">c3</a></h5> </div> </div> <div style="display: inline;"> <h4>9999</h4> </div> </div> </body> </html> ``` 问题: 这个sec:标签貌似并不起作用 第一次登陆游客的时候 ``` <div sec:authorize="!isAuthenticated()"> 游客您好!<a th:href="@{/login}">请登录</a> </div> <div sec:authorize="isAuthenticated()"> <span sec:authentication="name"></span>,您好!(<span sec:authentication="principal.getAuthorities()"></span>) ``` 全显示出来了 请问咋回事??????
mysql,查询语句的问题,谢谢。
SELECT max(MTAUT_INDEX),MTAUT_PARID FROM MT005AUT WHERE LOCATE('MT10000', MTAUT_PARID) > 0 我想查询mtaut_index的最大值,还得同时mtaut_parid里包含mt10000的值,这个语法好像不对,哪位帮帮忙,谢谢 ``` SELECT * FROM MT005AUT WHERE LOCATE('MT10000', MTAUT_PARID) > 0 and MTAUT_INDEX=(SELECT max(MTAUT_INDEX) FROM MT005AUT) ```
mysql,sql查询问题,谢谢解答
1.SELECT MTAUT_ID,MTAUT_PARID FROM MT005AUT WHERE MTAUT_ID = 'MT10011' 2.SELECT MTAUT_ID,MTAUT_PARID,MTAUT_NAME,MTAUT_ADDRESS FROM MT005AUT WHERE MTAUT_PARID LIKE 'MT10000,MT10011%' 第1次查询是想获取MTAUT_PARID,然后在通过MTAUT_PARID去查询和这个值相关的数据,如何能把这两个语句并成一条语句写呢?谢谢解答 可能是我表述有问题,你们看到那个百分号没?
mysql,同时查询问题?
select MTAUT_ID,MTAUT_INDEX,MTAUT_PARID from MT005AUT where MTAUT_PARID like '%,%,%' and MTAUT_PARID in ('MT10000') 想同时查询mtaut_parid里有2个逗号,还得有mt10000字符串,这个语法看来不对?
这种 xml咋解析?这种 xml咋解析这种 xml咋解析这种 xml咋解析这种 xml咋解析
<?xml version="1.0" encoding="UTF-8"?> <POOR_IN200901UV ITSVersion="XML_1.0" xmlns="urn:hl7-org:v3" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:hl7-org:v3 ../../Schemas/POOR_IN200901UV20.xsd"> <!-- 消息ID --> <id extension="BS002" /> <!-- 消息创建时间 --> <creationTime value="20120106110000" /> <!-- 交互ID --> <interactionId root="" extension="POOR_4" /> <!-- 消息用途: P(Production); D(Debugging); T(Training) --> <processingCode code="P" /> <!-- 消息处理模式: A(Archive); I(Initial load); R(Restore from archive); T(Current processing) --> <processingModeCode code="T" /> <!-- 消息应答: AL(Always); ER(Error/reject only); NE(Never) --> <acceptAckCode code="NE" /> <!-- 接受者 --> <receiver typeCode="RCV"> <device classCode="DEV" determinerCode="INSTANCE"> <!-- 接受者ID --> <id /> </device> </receiver> <!-- 发送者 --> <sender typeCode="SND"> <device classCode="DEV" determinerCode="INSTANCE"> <!-- 发送者ID --> <id /> </device> </sender> <!-- 封装的消息内容(按Excel填写) --> <controlActProcess classCode="CACT" moodCode="EVN"> <!-- 消息交互类型 @code: 新增 :new 删除:delete--> <code code="new"></code> <subject typeCode="SUBJ" xsi:nil="false"> <placerGroup classCode="GROUPER" moodCode="RQO"> <subject typeCode="SBJ"> <patient classCode="PAT"> <id> <!-- 域ID --> <item root="1.2.156.112606.1.2.1.2" extension="01" /> <!-- 患者ID --> <item root="1.2.156.112606.1.2.1.3" extension="09102312" /> <!-- 就诊号 --> <item root="1.2.156.112606.1.2.1.12" extension="0910238" /> </id> <!-- 病区编码/病区名 床号 --> <addr xsi:type="BAG_AD"> <item use="TMP"> <part type="BNR" value="9A血液科" code="09808" codeSystem="1.2.156.112606.1.1.33" codeSystemVersion="东北国际医院OID病区" /> <part type="CAR" value="06" /> </item> </addr> <!--个人信息 必须项已使用 --> <patientPerson classCode="PSN"> <!-- 身份证号/医保卡号 --> <id> <!-- 身份证号 --> <item extension="110938197803030456" root="1.2.156.112606.1.2.1.9" /> <!-- 医保卡号 --> <item extension="191284777494877" root="1.2.156.112606.1.2.1.11" /> </id> <!--姓名 --> <name xsi:type="BAG_EN"> <item> <part value="张三" /> </item> </name> <!-- 联系电话 --> <telecom xsi:type="BAG_TEL"> <!-- 联系电话 --> <item value="15801020489"></item> </telecom> <!--性别代码 --> <administrativeGenderCode code="1" codeSystem="1.2.156.112606.1.1.3" codeSystemName="东北国际医院OID性别代码"/> <!--出生日期 --> <birthTime value="19870202"> <!--年龄 --> <originalText value="25" /> </birthTime> <!--住址 --> <addr xsi:type="BAG_AD"> <item use="H"> <part type="AL" value="沈阳铁西区" /> </item> </addr> <!--婚姻状况类别编码 --> <maritalStatusCode code="10" codeSystem="1.2.156.112606.1.1.4" codeSystemName="东北国际医院OID婚姻状况" /> <!--民族编码 --> <ethnicGroupCode> <item code="HA" codeSystem="1.2.156.112606.1.1.5" codeSystemName="东北国际医院OID民族代码" /> </ethnicGroupCode> <!--雇佣关系 --> <asEmployee classCode="EMP"> <!--职业编码 --> <occupationCode code="6-24" codeSystem="1.2.156.112606.1.1.7" codeSystemName="东北国际医院OID职业"> <!--职业 --> <displayName value="重有色金属冶炼人员"></displayName> </occupationCode> <!--工作单位 --> <employerOrganization determinerCode="INSTANCE" classCode="ORG"> <!--工作单位名称 --> <name xsi:type="BAG_EN"> <item> <part value="中钢" /> </item> </name> <contactParty classCode="CON" xsi:nil="true" /> </employerOrganization> </asEmployee> <!--公民身份 --> <asCitizen> <!--所属国家 --> <politicalNation> <!--国籍编码 --> <code code="156" codeSystem="1.2.156.112606.1.1.6" codeSystemName="东北国际医院OID国藉"> <!--国家 --> <displayName value="中国"></displayName> </code> </politicalNation> </asCitizen> <!--联系人 --> <contactParty classCode="CON"> <!--联系人电话--> <telecom xsi:type="BAG_TEL"> <item use="MC" value="13899095656" capabilities="voice" /> </telecom> <!--联系人姓名/亲属 --> <contactPerson> <name xsi:type="BAG_EN"> <item use="IDE"> <part value="李四 " /> </item> </name> </contactPerson> </contactParty> </patientPerson> <providerOrganization determinerCode="INSTANCE" classCode="ORG"> <!-- 必须项 未使用 --> <id></id> <!--申请医院 保留可不填 --> <name xsi:type="BAG_EN"> <item> <part value="东北国际医院" /> </item> </name> </providerOrganization> </patient> </subject> <!--开医嘱者/送检医生 --> <author typeCode="AUT"> <!-- 开单时间 --> <time value="201205061000"></time> <assignedEntity classCode="ASSIGNED"> <!--开单医生编码 --> <id> <item extension="09882374" root="1.2.156.112606.1.1.2" /> </id> <!--开单医生姓名 --> <assignedPerson determinerCode="INSTANCE" classCode="PSN"> <name xsi:type="BAG_EN"> <item> <part value="李武" /> </item> </name> </assignedPerson> <!-- 申请科室信息 --> <representedOrganization determinerCode="INSTANCE" classCode="ORG"> <!--申请科室编码 必须项已使用 --> <id> <item extension="023984" root="1.2.156.112606.1.1.1" /> </id> <!--申请科室名称 --> <name xsi:type="BAG_EN"> <item> <part value="骨科" /> </item> </name> </representedOrganization> </assignedEntity> </author> <!-- 确认人 --> <verifier typeCode="VRF"> <!--确认时间 -->
AutoCompleteTextView显示的提示信息顺序有问题,求戳进来看看。感激不尽!
问题描述:例如我想查询123的公交信息,但是最后的提示却是1或者12或者123的信息结果, 原因应该是我在输入123时一次依次对1->12->123进行网络请求,但是响应的顺讯不是依次的才导致这问题的出现。 但是想不到好的办法解决 ,求大牛们发表下意见。
编译原理之设计扫描器,请问哪里有问题怎么改,为什么死循环
#include "string.h" #include "math.h" #include "stdio.h" char keywords[30][12]={"program","begin","end","var","while","do","repeat", "until","for","to","if","then","else",";", ":", "(", ")", ",", ":=", "+", "-", "*", "/", ">", ">=", "==", "<", "<="}; int num_key=28; int aut[11][8]={ 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 8, 9,15, 0, 2, 3, 5,11, 0, 0,11, 0, 4, 0, 0, 0, 0, 0, 0, 0, 4, 0, 5,11, 0, 0,11, 0, 7, 0, 0, 6, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, 0, 0, 7, 0, 0,11, 0, 0,11, 0, 8, 0, 0, 0, 8, 0,12, 0, 0, 0, 0, 0, 0,10,14, 0, 0, 0, 0, 0, 0, 0,13}; char ID[50][12]; int C[20]; int num_ID=0,num_C=0; struct token { int code; int value; }; //Token结构 struct token tok[100]; //Token数组 int i_token=0,num_token=0; //Token计数器和Token个数 char strTOKEN[15]; //当前单词 int i_str; //当前单词指针 int n,p,m,e,t; //尾数值,指数值,小数位数,指数符号,类型 double num; //常数值 char w[50]; //源程序缓冲区 int i; //源程序缓冲区指针,当前字符为w[i] struct map //当前字符到状态转换矩阵列标记的映射 { char str[50]; int col; }; struct map col1[4]={{"0123456789",1},{".",2},{"Ee",3},{"+-",4}}; //数字 struct map col2[2]={{"abcdefghijklmnopqrstuvwxyz",5},{"0123456789",1}}; //关键字或标识符 struct map col3[1]={{";:(),+-*/=><",6}}; //界符 struct map *ptr; int num_map; void act(int s); int find(int s,char ch); int InsertConst(double num); int Reserve(char *str); int InsertID(char *str); int main(int argc, char* argv[]) { FILE *fp; int s; //当前状态 fp=fopen("exa.txt","r"); while (!feof(fp)) { fgets(w,50,fp); i=0; do { while (w[i]==' ') //滤空格 i++; if (w[i]>='a' && w[i]<='z') //判定单词类别 { ptr=col2; num_map=2; } else if (w[i]>='0' && w[i]<='9') { ptr=col1; num_map=4; } else if (strchr(col3[0].str,w[i])==NULL) { printf("非法字符%c\n",w[i]); i++; continue; } else { ptr=col3; num_map=1; } i--; s=1; //开始处理一个单词 while (s!=0) { act(s); if (s>=11 && s<=14) break; i++; //getchar() s=find(s,w[i]); } if (s==0) { strTOKEN[i_str]='\0'; printf("词法错误:%s\n",strTOKEN); } }while (w[i]!=10); } printf("关键字表:"); //输出结果 for (i=0;i<30;i++) printf("%s ",keywords[i]); printf("\n"); printf("Token序列:"); for (i=0;i<num_token;i++) printf("(%d,%d)",tok[i].code,tok[i].value); printf("\n"); printf("符号表:"); for (i=0;i<num_ID;i++) printf("%s ",ID[i]); printf("\n"); printf("常数表:"); for (i=0;i<num_C;i++) printf("%d ",C[i]); printf("\n"); fclose(fp); printf("Hello World!\n"); return 0; } void act(int s) { int code; switch (s) { case 1:n=0;m=0;p=0;t=0;e=1;num=0;i_str=0; strTOKEN[i_str]='\0'; //其它变量初始化 break; case 2:n=10*n+w[i]-48; break; case 3:t=1; break; case 4:n=10*n+w[i]-48; m++; break; case 5:t=1; break; case 6:if (w[i]=='-') e=-1; break; case 7:p=10*p+w[i]-48; break; case 8:strTOKEN[i_str++]=w[i]; //将ch中的符号拼接到strTOKEN的尾部; break; case 9:strTOKEN[i_str++]=w[i]; //将ch中的符号拼接到strTOKEN的尾部; break; case 10:strTOKEN[i_str++]=w[i]; //将ch中的符号拼接到strTOKEN的尾部; break; case 11:num=n*pow(10,e*p-m); //计算常数值 tok[i_token].code=2; tok[i_token++].value=InsertConst(num); //生成常数Token num_token++; break; case 12:strTOKEN[i_str]='\0'; code=Reserve(strTOKEN); //查关键字表 if (code) { tok[i_token].code=code; tok[i_token++].value=0; } //生成关键字Token else { tok[i_token].code=1; tok[i_token++].value=InsertID(strTOKEN); } //生成标识符Token num_token++; break; case 13:strTOKEN[i_str]='\0'; code=Reserve(strTOKEN); //查界符表 if (code) { tok[i_token].code=code; tok[i_token++].value=0; } //生成界符Token else { strTOKEN[strlen(strTOKEN)-1]='\0'; //单界符 i--; code=Reserve(strTOKEN); //查界符表 tok[i_token].code=code; tok[i_token++].value=0; //生成界符Token } num_token++; break; case 14:strTOKEN[i_str]='\0'; code=Reserve(strTOKEN); //查界符表 tok[i_token].code=code; tok[i_token++].value=0; //生成界符Token num_token++; break; } } int find(int s,char ch) { int i,col=7; struct map *p; p=ptr; for (i=0;i<num_map;i++) if (strchr((p+i)->str,ch)) { col=(p+i)->col; break; } return aut[s][col]; } int InsertConst(double num) { int i; for (i=0;i<num_C;i++) if (num==C[i]) return i; C[i]=num; num_C++; return i; } int Reserve(char *str) { int i; for (i=0;i<num_key;i++) if (!strcmp(keywords[i],str)) return (i+3); return 0; } int InsertID(char *str) { int i; for (i=0;i<num_ID;i++) if (!strcmp(ID[i],str)) return i; strcpy(ID[i],str); num_ID++; return i; }
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
漫话:什么是平衡(AVL)树?这应该是把AVL树讲的最好的文章了
这篇文章通过对话的形式,由浅入深带你读懂 AVL 树,看完让你保证理解 AVL 树的各种操作,如果觉得不错,别吝啬你的赞哦。 1、若它的左子树不为空,则左子树上所有的节点值都小于它的根节点值。 2、若它的右子树不为空,则右子树上所有的节点值均大于它的根节点值。 3、它的左右子树也分别可以充当为二叉查找树。 例如: 例如,我现在想要查找数值为14的节点。由于二叉查找树的特性,我们可...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
      11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下
《C++ Primer》学习笔记(六):C++模块设计——函数
专栏C++学习笔记 《C++ Primer》学习笔记/习题答案 总目录 https://blog.csdn.net/TeFuirnever/article/details/100700212 —————————————————————————————————————————————————————— 《C++ Primer》习题参考答案:第6章 - C++模块设计——函数 文章目录专栏C+...
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车? 某胡同口的煎饼摊一年能卖出多少个煎饼? 深圳有多少个产品经理? 一辆公交车里能装下多少个乒乓球? 一
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法不过,当我看了源代码之后这程序不到50
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
MySQL数据库总结
文章目录一、数据库简介二、MySQL数据类型(5.5版本)三、Sql语句(1)Sql语句简介(2)数据定义语言DDLcreate,alter,drop(3)数据操纵语言DMLupdate,insert,delete(4)数据控制语言DCLgrant,revoke(5)数据查询语言DQLselect(6)分组查询与分页查询group by,limit四、完整性约束(单表)五、多表查询六、MySQL数
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
中年危机,35 岁定律,见鬼去吧!
中年危机,35 岁定律,相信你都听说过,每次触及还会让你感到丝丝焦虑,毕竟时间这把杀猪刀不会放过任何一个人。中年危机或 35 岁定律是客观存在的,你迟早都会遭遇的,那你是否有信心战胜它呢? 中年危机之所以让人害怕,一则是你没有把握打赢这场遭遇战,再则中年是一个输不起的阶段。古人云:知己知彼,百战不殆。恐惧,主要源自对敌人和自己的不了解,不知道敌人的优劣势,也不清楚自己的长短板,常常以己之所短攻彼...
程序设计的5个底层逻辑,决定你能走多快
阿里妹导读:肉眼看计算机是由CPU、内存、显示器这些硬件设备组成,但大部分人从事的是软件开发工作。计算机底层原理就是连通硬件和软件的桥梁,理解计算机底层原理才能在程序设计这条路上越走越快,越走越轻松。从操作系统层面去理解高级编程语言的执行过程,会发现好多软件设计都是同一种套路,很多语言特性都依赖于底层机制,今天董鹏为你一一揭秘。 结合 CPU 理解一行 Java 代码是怎么执行的 根据冯·诺...
张小龙-年薪近3亿的微信之父,他是如何做到的?
张小龙生于湖南邵东魏家桥镇, 家庭主要特点:穷。 不仅自己穷,亲戚也都很穷,可以说穷以类聚。爷爷做过铜匠,总的来说,标准的劳动阶级出身。 家有兄弟两人, 一个小龙,一个小虎。 小虎好动,与邻里打成一片, 小龙好静,喜好读书。 “文静的像个妹子。”张小龙的表哥如是说。 穷文富武,做个读书郎是个不错的选择。 87年至94年, 华中科技大学本硕连读。 本科就读电信系, 不喜欢上课
阿里靠什么武功秘籍渡过“双十一“的天量冲击
双十一大概会产生多大的数据量呢,可能大家没概念,举个例子央视拍了这么多年电视新闻节目,几十年下来他存了大概80P的数据。而今年双11一天,阿里要处理970P的数据,做为一个IT人,笔者认为今年”双十一“阿里最大的技术看点有有以下两个: 阿里的数据库,也就是刚刚拿下TPC冠军的OcceanBase,处理峰值也达到了骇人听闻的6100万次/秒, 阿里核心系统百分百上云了。 如果把信息系统比做一个武
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
相关热词 c# 二进制截断字符串 c#实现窗体设计器 c#检测是否为微信 c# plc s1200 c#里氏转换原则 c# 主界面 c# do loop c#存为组套 模板 c# 停掉协程 c# rgb 读取图片
立即提问