修改chrome 扩展ID 修改chrome 扩展ID

修改chrome 扩展ID
this.loadingImg="chrome-extension://pcbkaponcbg/img/loading1.gif";
改完后ID仍是ID: hjiebjanphijpacjiimolpcbkaponcbg

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
JS / Chrome扩展:如何检查登录用户

<div class="post-text" itemprop="text"> <p>I've built a Chrome extension and now id' like to integrate it with my current website built in PHP where users have their own account and can save stuff (think something like pinterest)... </p> <p>Is it possible to drop a cookie from PHP when they login to my website and read it from the Chrome/Js app? I just need to save the unique ID of the user, but I'm not sure if I can read my cookie from a different website...</p> <p>What's the correct approach?</p> </div>

在自己的html中可以加载chrome的扩展吗,就是普通的html,不是popup

在自己的html中可以加载chrome的扩展吗,就是普通的html,不是popup

chrome插件中回调函数与call的用法

如下是一个下载页面内所有图片的chrome扩展代码,其中的 [].map.call是什么意思,background中的results与url参数的数据又是哪里来的? background.js: ``` chrome.runtime.onInstalled.addListener(function(){ chrome.contextMenus.create({ 'id':'saveall', 'type':'normal', 'title':'save all picture', }); }); chrome.contextMenus.onClicked.addListener(function(info, tab){ if(info.menuItemId == 'saveall'){ chrome.tabs.executeScript(tab.id, {file: 'main.js'}, function(results){ if (results && results[0] && results[0].length){ results[0].forEach(function(url) { chrome.downloads.download({ url: url, conflictAction: 'uniquify', saveAs: false }); }); } }); } }); ``` main.js: ``` [].map.call(document.getElementsByTagName('img'), function(img){ return img.src; }); ```

(chrome 扩展)javascript的异步嵌套函数调用, 请教前辈!!!!

背景: 小弟开发了一个在content Script 和 Background Page 之间不断互相嵌套调用的Chrome Extension 在进行了2次嵌套调用后出错。 而我根本无法知道为何里面的代码不执行。 --------------------------------- **出错的地方: background.js 的第九行;** 前辈们帮忙啊!!! -------------------------------- 所有代码如下(option page是空的, 我就没放上来): ``` <manifest.js> { "manifest_version": 2, "name": "Getting started example", "description": "This extension shows a Google Image search result for the current page", "version": "1.0", "options_page": "options.html", "browser_action": { "default_icon": "icon.png", "default_popup": "popup.html" }, "permissions": [ "activeTab", "storage", "tabs", "*://*/*", "background" ], "content_scripts": [ { "matches": ["*://*/*"], "js": ["content.js"], "run_at": "document_start" } ], "background": { "scripts": ["background.js"] } } ``` ``` <popup.js> function start_action() { var bloggerID = document.getElementById('bloggerID').value; var handleQty = document.getElementById('handleQty').value; var bkg = chrome.extension.getBackgroundPage(); bkg.doSomeThing(function(result) { alert( result ); }); } function restore_options() { } document.addEventListener('DOMContentLoaded', restore_options); document.getElementById('start').addEventListener('click', start_action); ``` ``` <content.js> chrome.extension.onRequest.addListener( function (request, sender, sendResponse) { if (request.action == "findCandidates") { var oCandidateList = candidateList(); var nameList = new Array(); for (i = 0;i < oCandidateList.length; i++) { nameList[i] = oCandidateList[i].innerHTML; } sendResponse( nameList ); } } ); chrome.extension.onRequest.addListener( function (request, sender, sendResponse) { if (request.action == "openCandidatePage") { var oCandidateList = candidateList(); for (i = 0;i < oCandidateList.length; i++) { if ( oCandidateList[i].innerHTML == request.candidateName ) { oCandidateList[i].click(); break; } } sendResponse(); } } ); chrome.extension.onRequest.addListener( function (request, sender, sendResponse) { if (request.action == "doFinalJobs") { alert("do the final jobs"); } } ); function candidateList() { var oTags = document.getElementsByTagName("a"); var oResultTags = new Array; for (i=0; i<oTags.length; i++){ if ( oTags[i].hasAttribute("usercard") && oTags[i].hasAttribute("node-type") ) { oResultTags[oResultTags.length] = oTags[i]; } } return oResultTags; } ``` ``` <background.js> function doSomeThing (callback) { chrome.tabs.getSelected(null, function (fatherTab) { chrome.tabs.sendRequest(fatherTab.id, { action: "findCandidates" }, function (candidates) { for (i = 0;i < 1; i++) { chrome.tabs.sendRequest( fatherTab.id, { action: "openCandidatePage", candidateName: candidates[i] }, function(doNothing) { callback("WHY HERE GOSE NO RESPOND"); // 就是这里开始任何代码都不执行 , 也不报错。 之前的所有功能都正常。 }); } }); }); } ```

Chrome插件popup.js的onclick无效

![图片说明](https://img-bbs.csdn.net/upload/201909/30/1569859047_746637.png) **插件的主要功能是:** 输入关键词,点击搜索,即调用a.js和b.js,分别在不同搜索引擎中进行搜索。 本功能在普通html中可以实现,但是转为chrome扩展后,因本人处理不好onclick事件,点击搜索无效。 本人是扩展小白,请懂的兄弟姐妹施以援手! popup.html如下: ``` <head> <script src="popup.js"></script> </head> <body> <div class="search clearfix"> <input type="text" name="q" id="bdcsMain" value="关键词" onfocus="if (value ==关键词'){value =''}" onblur="if (value ==''){value='关键词'}" > <button class="search" type="submit" id="click-this">搜索</button> </div> <script src="scripts/a.js"></script> <script src="scripts/b.js"></script> </body> ``` popup.js如下: ``` document.addEventListener('DOMContentLoaded', function() { document.getElementById("click-this").addEventListener("click", "a();b();");}) ```

从chrome扩展程序验证saml会话

<div class="post-text" itemprop="text"> <p>I've implemented <a href="https://simplesamlphp.org/" rel="nofollow">simpleSAMLphp</a> and setup a test environment by following the mentioned link, its working good so far. I'm able to authenticate users from provided IDPs. What I'm trying to do next is to get that SAML authenticated session in my chrome app and see if user is logged in or not. </p> <p>Is it possible? any help is highly appreciated. Please let me know if my question is not clear enough.</p> <p>Thanks! </p> </div>

如何从数据库中检索信息以使用Chrome扩展程序显示

<div class="post-text" itemprop="text"> <p>I am trying to write my first chrome extension. The workflow goes something like this -When the extension is installed and active if a user hovers over a specific product/ID displayed on the page, the extension retrieves related vendor data about the product with the ID.</p> <p>This is how I thought about this:</p> <ol> <li>Use jQuery attr to access the ID on mouse over.</li> <li>Post this ID to a retrieve.php file with .post() method</li> <li>The retrieve.php file retrieves the data from database</li> <li>Display the data in a tool tip on the web page.</li> </ol> <p>I have some queries for the above process:</p> <ol> <li><p>I am able to get this working on a local XAMPP server but how will it work online as the chrome extension will not have access to server. What is the way around to retrieve data without using PHP?</p></li> <li><p>I am able to get the logic working but am unable to place these in respective files - Will all my logic reside in background.js ?</p></li> </ol> <p>Any suggestions on getting this started will be much appreciated.</p> </div>

Google Chrome扩展程序javascript打开新标签问题

<div class="post-text" itemprop="text"> <p>I'm making an extension for google chrome that allows people put player id in a field and press snap and a new tab will be opened with the url the text that user typed.</p> <p>Any idea what js codes should I use for the url text in new tab?</p> <p>Edit: What I did:</p> <p>I used php instead of js</p> <p>I used <code>$_Post["name"]</code> but there is problem too!</p> <p>I need the var to appear only like the person typed it... not with <code>key=var</code></p> </div>

让AJAX在chrome扩展中工作?

<div class="post-text" itemprop="text"> <p>I'm attempting to send a mail from a chrome extension.I could successfully perform the task using php. However I wanted to make the process asynchronous using ajax. I made the necessary changes. I can display "mail sent successfully" on same page without redirecting to another page in normal html window but, when I try to do the same inside an extension the whole php page gets loaded instead of echo message. </p> <pre><code>**manifest.json** { "name":"extmail", "description":"Quicky send emails to your contacts", "version":"2.0", "permissions":["activeTab"], "background":{ "script":["js/script.js"], "script":["js/submit.js"] }, "content_security_policy": "script-src 'self' https://ajax.googleapis.com; object-src 'self'", "browser_action":{ "default_title":"TinyMessage", "default_icon":"images/icon.png", "default_popup":"popup.html" }, "manifest_version": 2 } **submit.js** $(document).ready(function(){ $(".image").click(function(){ //on click image var name = $(this).attr("name"); //declare name as email var url=$("#temp").val(); //set email to hidden input as value var message=$("#message").val(); //to work asynchronously var Url="php/mail.php"; var httpRequest; httpRequest=new XMLHttpRequest(); httpRequest.onreadystatechange=sendUrl; httpRequest.open("POST",Url,true); httpRequest.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); httpRequest.send("url="+url+"&amp;toemail="+name+"&amp;message="+message); function sendUrl() { if(httpRequest.readyState==httpRequest.DONE) if(httpRequest.status==200) { var response=httpRequest.responseText; document.getElementById("response").innerHTML=response; } } }); }); **mail.php** &lt;?php session_start(); $url = $_POST['url']; // getting url $toemail = $_POST['toemail']; $message = $_POST['message']; // getting message $to = $toemail; // to email address $subject = "sent from extension"; // assign subject $txt = "$url $message"; $headers = "From: donotreply@fmt.com"; // Sending mail if(mail($to,$subject,$txt,$headers)){ // mail function send mail using a smtp server echo "mail sent successfully "; } else{ echo "mail not sent"; } ?&gt; **popup.html** &lt;html&gt; &lt;head&gt; &lt;title&gt;Easy Mail&lt;/title&gt; &lt;script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"&gt;&lt;/script&gt; &lt;script type="text/javascript" src="js/script.js"&gt;&lt;/script&gt; &lt;script type="text/javascript" src="js/submit.js"&gt;&lt;/script&gt; &lt;script type="text/javascript" src="js/load.js"&gt;&lt;/script&gt; &lt;link rel="stylesheet" type="text/css" href="css/style.css"&gt; &lt;/head&gt; &lt;body&gt; &lt;h1&gt;Tiny MESSAGE!&lt;/h1&gt; &lt;form action="http://localhost/extmail/php/mail.php" id="form1" method="POST"&gt; &lt;input id="toemail" type="hidden" name="toemail" &gt; &lt;input id="temp" name="url"&gt; &lt;label for="message"&gt;Enter message:&lt;/label&gt;&lt;br/&gt; &lt;input id="message" type="text" name="message"&gt; &lt;!-- &lt;input type="submit" value="send Mail"&gt; --&gt; &lt;br&gt; &lt;br&gt; &lt;img class="image" id="image1" name="temp@example.com" src="images/contact1.jpg" title="temp@example.com" alt="Smiley face" height="40" width="40"&gt;&lt;span id="badge1"&gt;&lt;/span&gt; &lt;figcaption&gt;contactone&lt;/figcaption&gt; &lt;/form&gt; &lt;div id="response"&gt;&lt;/div&gt; &lt;/body&gt; </code></pre> <p></p> </div>

为什么我适用chrome.tabs.executeScript没有反应

我要实现这样一个功能:打开一个新tab时,如果浏览器已经存在百度网站的tab,那么就在这个百度tab里注入一段代码(为了测试方便,这里就用alert语句)。 这里tb[0].id自然就是那个被抓取到的百度tab的ID,经单独测试没有错误,是有数值的。但是后面那个code就一直执行不了,换成file也不行,不知道什么原因,请求大神解答 chrome.tabs.onCreated.addListener(function(tab) { chrome.tabs.query({url:"https://www.baidu.com/"},function(tb){ chrome.tabs.executeScript(tb[0].id,{code:"window.alert(11)"},null); }); }); ------------------------------------------- json文件: { "manifest_version": 2, "name": "demo", "version": "1.0.0", "description": "简单的Chrome扩展demo", "permissions": ["storage","tabs","activeTab"], "background": { "scripts": ["background.js"], "persistent": false } }

如何从chrome扩展名向php sql数据库提交表单数据

<div class="post-text" itemprop="text"> <p>I don't know whats wrong with this code but it is not working. I changed form method to post and get but nothing worked. I want to submit this form to DB.</p> <p><code>popup.html:</code></p> <pre><code>&lt;form id='myForm' action='savenewfeed.php' method="get"&gt; URL: &lt;input class= 'vals' type="text" name="feed" id="url"&gt; &lt;br&gt; Title : &lt;input class= 'vals' type="text" name="title" id="title"&gt; &lt;br&gt; Channel: &lt;select class= 'vals' name='pid'&gt; &lt;option value="2"&gt;Big&lt;/option&gt; &lt;option value="3"&gt;H&lt;/option&gt; &lt;option value="4"&gt;T&lt;/option&gt; &lt;/select&gt; &lt;button id='sbmt'&gt;Submit&lt;/button&gt; &lt;/form&gt; </code></pre> <p><code>manifest:</code></p> <pre><code>{ "manifest_version": 2, "name": "One-click Kittens", "description": "This extension gets current url of browser", "version": "1.0", "permissions": [ "tabs", "cookies", "http://*/*", "http://*/", "https://*/*" ], "browser_action": { "default_icon": "icon.png", "default_popup": "popup.html" } } </code></pre> <p>popup.js:</p> <pre><code>function myAlert(){ document.getElementById('myForm').submit(); } document.addEventListener('DOMContentLoaded', function () { document.getElementById('sbmt').addEventListener('click', myAlert); }); </code></pre> <p>when i click the button, my php code appears in chrome extension, whereas , that php code to submit data works perfectly in simple web app.</p> </div>

chrome插件开发的问题,contentscript与popup相关

插件页面上的调用如下 ``` chrome.tabs.getSelected(null, function (tab) { chrome.tabs.executeScript(tab.id, { code: "plocalize(" + paramString + ");" }, function () { console.log('done'); }); }); ``` plocalize在contentscript的一个js文件中 但是有时候必须刷新当前页面,否则会报出Uncaught ReferenceError: plocalize is not defined错误,但这时候看到页面的contentscript里是有这个文件的 不知道描述的清不清楚,有什么问题我再解释

chrome浏览器插件content_scripts无法调用iframe下的元素,求大神帮忙。

现在想搞一个插件,可以实现页面的自动点击,结果发现这个网页包含一个iframe的,具体以下代码: 主页面代码: ``` <html><head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>开通业务确认</title> <link rel="stylesheet" href="/page/swcl/css/easyui.css" type="text/css" media="screen"> <script src="/page/swcl/js/jquery.min.js"></script> <script src="/page/cm/js/jquery.easyui.min.js"></script> <script src="/page/swcl/platform/js/easyui-lang-zh_CN.js"></script> <script src="/page/swcl/sunshine/js/clipboard.min.js"></script> <script src="/page/swcl/sunshine/js/migu.js"></script> <script> var urlPrefix = ""; var errorMsg=""; var memberType=parseInt("0"); var netId="ba1b41f7e0634a2a997c8d071651704d"; var authId="e9419cd15c484e28af5f8774abec49b1"; var openBizOrder = {}; openBizOrder.netId="ba1b41f7e0634a2a997c8d071651704d"; openBizOrder.authId="e9419cd15c484e28af5f8774abec49b1"; openBizOrder.productionId="698039020020006005"; openBizOrder.price=parseInt("500"); openBizOrder.channelId="014Z020"; openBizOrder.orderId="0120520171116299428725"; var openBizOrderDesc="欢迎开通中国移动咪咕音乐企业彩铃功能业务"; var isMutiOrder = "false"; if(isMutiOrder=="true"){ var nextOpenBizOrder = {}; nextOpenBizOrder.netId=""; nextOpenBizOrder.authId=""; nextOpenBizOrder.productionId=""; nextOpenBizOrder.price=parseInt(""); nextOpenBizOrder.channelId=""; nextOpenBizOrder.orderId=""; var nextOpenBizOrderDesc=""; } var h5AppUrl = ""; </script> <script src="/page/swcl/sunshine/js/openBizConfirm2.js"></script> <script id="h5AppUrl" data="" type="text/javascript"></script> </head> <body> <div id="payDetailTag" style="background: rgb(255, 255, 255); position: fixed; z-index: 1000; left: 0px; top: 0px; display: block; -webkit-box-align: center; align-items: center; width: 100%; height: 100%;"><div style="width: 100%; display: -webkit-box; display: -ms-flexbox; display: -webkit-flex; display: -moz-flex; -webkit-box-pack: center; -ms-flex-pack: center; -webkit-justify-content: center; -moz-justify-content: center; justify-content: center; text-align: center; height: 100%"><iframe id="frame" src="http://223.111.8.142:8080/migunetsdk/webJs/frame.html?netId=ba1b41f7e0634a2a997c8d071651704d&amp;umark=Common&amp;client=WAP" name="__migu_web_pay_frame" class="miguframe" style="position: absolute; top: 0; left: 0; border: 0; width: 100%; height: 100%;"></iframe></div><div id="payInfo" style="display: block;position:fixed;top: 0;left: 0;z-index: -1;text-align: center;width: 100%;height: 100%;background: #dedede;font-family: 微软雅黑;color: rgb(78, 78, 78);line-height:45px;font-size:1.525em;">欢迎开通中国移动咪咕音乐企业彩铃功能业务</div></div></body></html> ``` iframe页面的代码 ``` <html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-inline' 'unsafe-eval' http://wsdkdl.migu.cn:8080"><meta name="apple-mobile-web-app-capable" content="yes"><meta name="apple-mobile-web-app-status-bar-style" content="black"><meta content="width=device-width,initial-scale=1.0,minimum-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport"><link rel="stylesheet" type="text/css" href="http://wsdkdl.migu.cn:8080/music/Common/style.css?v=3d1thl8Ih4sFTxA3_IbMQ1"></head><body><script>var __url_res='http://wsdkdl.migu.cn:8080/music/Common';var __url_bin='http://wsdkdl.migu.cn:8080/ba1b41f7e0634a2a997c8d071651704d/1510773427830/netsdk_b.bin?v=3d1thl8Ih4sFTxA3_IbMQ1';var __s='e3e9adea218c4d4f9d535fc966d6170a';window.parent.postMessage('{"msgtype": "init2", "__s":"'+__s+'"}', '*');</script><script crossorigin="" src="http://wsdkdl.migu.cn:8080/ba1b41f7e0634a2a997c8d071651704d/1510773427830/netsdk_b.js?v=3d1thl8Ih4sFTxA3_IbMQ1"></script> <div id="payLoginTag" class="payLoginTag"><div class="payLogin"><div class="payLogo"><img src="http://wsdkdl.migu.cn:8080/music/Common/img/pay_logo_ear.gif"></div></div></div><div class="payDetail onkey" id="payDetail"><div class="close"><a href="javascript:;"><img src="http://wsdkdl.migu.cn:8080/music/Common/img/closeNavBtn_m.png" id="close"></a></div><div class="content"><div class="payName">包月费用:<span id="fee">¥5.00</span></div><div class="notice"><span id="notice">请输入手机号码及验证码,完成支付</span></div><div class="payInfo"><p>支付号码:<span class="payPhone" id="payPhone">183****7771</span></p></div><div class="okPay"><a href="javascript:;" id="okPay">确认支付</a></div><div class="footer onekeyFooter"><div class="footerImg"><img src="http://wsdkdl.migu.cn:8080/music/Common/img/bottom.png" id="discribe" class="top"></div><div class="logo"><img src="http://wsdkdl.migu.cn:8080/music/Common/img/migu-logo.png" class="migulogo" id="logo"></div><div class="clear"></div><div class="describe" id="detailInfo"><p>本支付由中国移动咪咕文化提供,付费金额将从您的话费中扣除。</p></div></div></div></div></body></html> ``` 我要提取到iframe中的一个a元素, 现在在content_scripts的js中直接写var okPay = document.getElementById("okPay");得到的却是null。在mainifest.json中也配置了js在iframe中应用,{ "matches": ["http://211.137.107.18:8888/cm/*","http://223.111.8.142:8080/migunetsdk/webJs/*"], "js": ["js/myscript2.js"], "all_frames":true }。希望大神们能帮忙看看,怎么解决。

扩展中未显示任何输出

<div class="post-text" itemprop="text"> <p>I got stuck in the project where i want to detect phishing website using machine learning. I have Extension but there is no output shown. I am using windows operating system. </p> <p>clientServer.php</p> <pre><code>&lt;?php header("Access-Control-Allow-Origin: *"); $site=$_POST['url']; $html = file_get_contents($site); echo $html; $bytes=file_put_contents('markup.txt', $html); //$a=exec('/usr/bin/python /opt/lampp/htdocs/BE/test.py '.$site.' 2&gt;&amp;1 '); $a=exec('/wamp64/www/test.py 2&gt;&amp;1' ,$site); echo $a; ?&gt; </code></pre> <p>popup.js</p> <pre><code>function transfer(){ var tablink; chrome.tabs.getSelected(null,function(tab) { tablink = tab.url; //alert(tablink); $("#p1").text("The URL being tested is - "+tablink); var xhr=new XMLHttpRequest(); //alert("hii"); //var tablink=''; //var safe = document.URL; params="url="+tablink; alert(params); var markup = "url="+tablink+"&amp;html="+document.documentElement.innerHTML; xhr.open("POST","http://localhost/clientServer.php", true); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.send(markup); alert(xhr.responseText); $("#div1").text(xhr.responseText); return xhr.responseText; /*if(xhr.responseText==6) { return "safe"; } return "nooooo";*/ }); } $(document).ready(function(){ $("button").click(function(){ var val = transfer(); // $("#p1").text(val); }); }); chrome.tabs.getSelected(null,function(tab) { var tablink = tab.url; $("#p1").text("The URL being tested is - "+tablink); }); </code></pre> <p>popup.html</p> <pre><code>&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"&gt;&lt;/script&gt; &lt;script src="popup.js" type = "text/javascript"&gt;&lt;/script&gt; &lt;link rel="stylesheet" href="style.css"&gt; &lt;/head&gt; &lt;body&gt; &lt;div&gt;&lt;h2&gt; Check your WebPage &lt;/h2&gt;&lt;/div&gt; &lt;div id = "p1"&gt;&lt;/div&gt; &lt;p&gt;Find out now...&lt;br&gt;&lt;sup&gt;&amp;darr;&lt;/sup&gt;&lt;/p&gt; &lt;div&gt;&lt;button class="button" &gt;&lt;span&gt;Safe or No?&lt;/span&gt;&lt;/button&gt; &lt;div id="div1"&gt;&lt;/div&gt; &lt;/div&gt; &lt;/body&gt; &lt;/html&gt; </code></pre> <p>I have put clientServer.php in www folder of wamp and also test.py that is my python file in wamp folder.</p> <p>See the extension, when i click on the safe/not button it does not show anything <img src="https://i.stack.imgur.com/UhMc2.png" alt=""> <img src="https://i.stack.imgur.com/qZVsE.png" alt=""> <img src="https://i.stack.imgur.com/eO4br.png" alt="enter image description here"></p> </div>

为什么这些对象属性未定义?

<div class="post-text" itemprop="text"> <p>I'm trying to access the properties of an object returned from my php script using <code>json_encode</code> like so:</p> <p>php</p> <pre><code>echo json_encode(array( 'person_id' =&gt; $personID, 'job_id' =&gt; $jobID) ); </code></pre> <p>JS</p> <pre><code>$.ajax({ url: url, cache: false, type: "POST" }).done(function(sData){ console.log(sData); console.log(sData.job_id); console.log(sData.person_id); }); </code></pre> <p>Output:</p> <pre><code>{"person_id":1,"job_id":1} undefined undefined </code></pre> <p>What's going on here? Why can't I access these properties?</p> <p><strong>UPDATE:</strong></p> <p>For any future visitors, this is a mistake I've made MANY, MANY times before (leaving out <code>dataType</code>) and will most certainly make again. </p> <p>It can be especially confusing because when you examine your server response in Chrome Dev Tools, it is automatically parsed as a JSON object (in the PREVIEW tab). </p> <p><img src="https://i.stack.imgur.com/IPAhR.jpg" alt="enter image description here"></p> <p>It's nice that Chrome does this, so that you can easily inspect your response data, however the same is not true for your javascript code, you WILL NEED to declare the proper <code>dataType</code> of the response so that your code can interpret the data as an object and not a string.</p> </div>

获取知道名称和可能扩展名的文件

<div class="post-text" itemprop="text"> <p>I'm working on a school project. I'm creating a webform that helps the user to edit some entries of a database (let's say I want to edit an entry of the 'books' table).</p> <p>First, I display a list of books, the user can click on the one he/she wants to edit and all the informations will be retrieved and displayed inside input forms, so that he/she can edit and then submit the updated data.</p> <p>I'm having one problem. Associated with each book there's a picture that I'd like to display, unfortunately all I can retrieve from the database is the name of the picture file but not the extension. The only extensions allowed are jpeg, gif, jpg and png. What I tried this far is the following function:</p> <pre><code>function UrlExists(url) { var ext = [ ".jpeg", ".jpg", ".png", ".gif" ]; var http = new XMLHttpRequest(); var url_ext = ''; $.each(ext, function(key, value){ http.open('HEAD', url+value, false); http.send(); if(http.status!=404){ url_ext = url+value; } }); if(url_ext){ return url_ext; }else{ return "image_path/notfound.jpg"; } } </code></pre> <p>It's not pretty but it works. The only side-problem are all the warnings on the dev-tool in chrome. I don't really mind but I feel like this is bad practice, I'm basically trying to retrieve the file hitting the server with every allowed extension.</p> <p>This code works because there are no files with the same name, so there cannot be "picture.jpg" AND "picture.png". Is there a good solution to this problem ? I tried using some php inside jquery, with the glob() function, but I couldn't make it work. Something like this:</p> <pre><code>$('#image_id').attr('src', '&lt;?php echo json_encode(glob("image_path/filename.{jpg,jpeg,png,gif}", GLOB_BRACE)) ?&gt;' ); </code></pre> <p>It's not really doing any php work, I think I'm missing something to make php work inside a jQuery function or maybe it runs when the document is loaded so it wouldn't work. Anyway I'm not even sure this can work. Any help would be much appreciated. Keep in mind I'm no php/jquery expert ;)</p> </div>

bootstrap的Tab切换不了标签页

``` @{ ViewBag.Title = "Index"; } <head> <script type="text/javascript" src="~/Content/bootstrap-3.0.3.min.js"></script> <script type="text/javascript" src="~/Content/jquery-2.0.0.min.js"></script> <link href="@Url.Content("~/Content/bootstrap-3.0.0.min.css")" rel="stylesheet" type="text/css" /> </head> <body> <ul id="myTab" class="nav nav-tabs"> <li class="active"> <a href="#home" data-toggle="tab"> W3Cschool Home </a> </li> <li><a href="#ios" data-toggle="tab">iOS</a></li> <li class="dropdown"> <a href="#" id="myTabDrop1" class="dropdown-toggle" data-toggle="dropdown"> Java <b class="caret"></b> </a> <ul class="dropdown-menu" role="menu" aria-labelledby="myTabDrop1"> <li><a href="#jmeter" tabindex="-1" data-toggle="tab">jmeter</a></li> <li><a href="#ejb" tabindex="-1" data-toggle="tab">ejb</a></li> </ul> </li> </ul> <div id="myTabContent" class="tab-content"> <div class="tab-pane fade in active" id="home"> <p>W3Cschoool菜鸟教程是一个提供最新的web技术站点,本站免费提供了建站相关的技术文档,帮助广大web技术爱好者快速入门并建立自己的网站。菜鸟先飞早入行——学的不仅是技术,更是梦想。</p> </div> <div class="tab-pane fade" id="ios"> <p> iOS 是一个由苹果公司开发和发布的手机操作系统。最初是于 2007 年首次发布 iPhone、iPod Touch 和 Apple TV。iOS 派生自 OS X,它们共享 Darwin 基础。OS X 操作系统是用在苹果电脑上,iOS 是苹果的移动版本。 </p> </div> <div class="tab-pane fade" id="jmeter"> <p>jMeter 是一款开源的测试软件。它是 100% 纯 Java 应用程序,用于负载和性能测试。</p> </div> <div class="tab-pane fade" id="ejb"> <p> Enterprise Java Beans(EJB)是一个创建高度可扩展性和强大企业级应用程序的开发架构,部署在兼容应用程序服务器(比如 JBOSS、Web Logic 等)的 J2EE 上。 </p> </div> </div> </body> ``` 运行发现页面没问题,点击没有反应,但是把引用的js换成这个就又可以了 ``` <link href="http://libs.baidu.com/bootstrap/3.0.3/css/bootstrap.min.css" rel="stylesheet"> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <script src="http://libs.baidu.com/bootstrap/3.0.3/js/bootstrap.min.js"></script> ``` 不知道是什么原因,求大神解答

图片上传,图片被压缩,求大神解答

asp.net图片上传,图片尺寸为2000:600(504kb),上传到服务器后变成了1600:480(62kb),百度后得出结果为要修改iis配置![图片说明](https://img-ask.csdn.net/upload/201601/15/1452828073_54193.png),修改后,通过input file上传的图片尺寸正常,但是通过js的webuploader上传,上传后的尺寸任然为1600:480,调试js发现,在js里获取的文件大小是正常,vs调试,ashx里面获取的图片大小改变了,求解 这段为input file 上传图片的后台代码 protected void btnUpload_Click(object sender, EventArgs e) { HttpFileCollection Files = HttpContext.Current.Request.Files; for (int i = 0; i < Files.Count; i++) { HttpPostedFile PostedFile = Files[i]; if (PostedFile.ContentLength > 0) { string FileName = PostedFile.FileName; string strExPrentFile = FileName.Substring(FileName.LastIndexOf(".") + 1); string sFilePath = "a.jpg"; PostedFile.SaveAs(Server.MapPath(sFilePath)); } else { } } } ``` ``` 这段为webuploader上传图片的后台代码 private void UpLoadFile(HttpContext context, string strUrl, string strToUrl,string userID) { Dsxy.Model.siteconfig siteConfig = new Dsxy.BLL.siteconfig().loadConfig(); string _delfile = DTRequest.GetString("DelFilePath"); HttpPostedFile _upfile = context.Request.Files["Filedata"]; bool _iswater = false; //默认不打水印 bool _isthumbnail = false; //默认不生成缩略图 if (DTRequest.GetQueryString("IsWater") == "1") _iswater = true; if (DTRequest.GetQueryString("IsThumbnail") == "1") _isthumbnail = true; if (_upfile == null) { context.Response.Write("{\"status\": 0, \"msg\": \"请选择要上传文件!\"}"); return; } UpLoad upFiles = new UpLoad(); string msg = upFiles.fileSaveAs(_upfile, _isthumbnail, _iswater, strUrl, strToUrl,userID); //删除已存在的旧文件,旧文件不为空且应是上传文件,防止跨目录删除 if (!string.IsNullOrEmpty(_delfile) && _delfile.IndexOf("../") == -1 && _delfile.ToLower().StartsWith(siteConfig.webpath.ToLower() + siteConfig.filepath.ToLower())) { Utils.DeleteUpFile(_delfile); } //返回成功信息 context.Response.Write(msg); context.Response.End(); } /// <summary> /// 文件上传方法 /// </summary> /// <param name="postedFile">文件流</param> /// <param name="isThumbnail">是否生成缩略图</param> /// <param name="isWater">是否打水印</param> /// <returns>上传后文件信息</returns> public string fileSaveAs(HttpPostedFile postedFile, bool isThumbnail, bool isWater,string strUrl=null,string strToUrl=null,string userID=null) { Dsxy.Model.siteconfig siteConfig = new Dsxy.BLL.siteconfig().loadConfig(); try { string fileExt = Utils.GetFileExt(postedFile.FileName); //文件扩展名,不含“.” int fileSize = postedFile.ContentLength; //获得文件大小,以字节为单位 string fileName = postedFile.FileName.Substring(postedFile.FileName.LastIndexOf(@"\") + 1); //取得原文件名 string newFileName = Utils.GetRamCode() + "." + fileExt; //随机生成新的文件名 //string newFileName = userID + "." + fileExt; //根据ID生成新的文件名 string newThumbnailFileName = "thumb_" + newFileName; //随机生成缩略图文件名 //string upLoadPath = GetUpLoadPath(); //上传目录相对路径 string upLoadPath = strToUrl; //上传目录相对路径 string fullUpLoadPath = AppDomain.CurrentDomain.BaseDirectory + upLoadPath; //try //{ // fullUpLoadPath = Utils.GetMapPath(upLoadPath); //上传目录的物理路径 //} //catch (Exception) //{ // fullUpLoadPath = AppDomain.CurrentDomain.BaseDirectory + upLoadPath; //} string newFilePath = upLoadPath + newFileName; //上传后的路径 string newThumbnailPath = upLoadPath + newThumbnailFileName; //上传后的缩略图路径 //检查文件扩展名是否合法 if (!CheckFileExt(fileExt)) { return "{\"status\": 0, \"msg\": \"不允许上传" + fileExt + "类型的文件!\"}"; } //检查文件大小是否合法 if (!CheckFileSize(fileExt, fileSize)) { return "{\"status\": 0, \"msg\": \"文件超过限制的大小!\"}"; } //检查上传的物理路径是否存在,不存在则创建 if (!Directory.Exists(fullUpLoadPath)) { Directory.CreateDirectory(fullUpLoadPath); } //保存文件 postedFile.SaveAs(fullUpLoadPath + newFileName); //如果是图片,检查图片是否超出最大尺寸,是则裁剪 if (IsImage(fileExt) && (this.siteConfig.imgmaxheight > 0 || this.siteConfig.imgmaxwidth > 0)) { Thumbnail.MakeThumbnailImage(fullUpLoadPath + newFileName, fullUpLoadPath + newFileName, this.siteConfig.imgmaxwidth, this.siteConfig.imgmaxheight); } //如果是图片,检查是否需要生成缩略图,是则生成 if (IsImage(fileExt) && isThumbnail && this.siteConfig.thumbnailwidth > 0 && this.siteConfig.thumbnailheight > 0) { Thumbnail.MakeThumbnailImage(fullUpLoadPath + newFileName, fullUpLoadPath + newThumbnailFileName, this.siteConfig.thumbnailwidth, this.siteConfig.thumbnailheight, "Cut"); } else { newThumbnailPath = newFilePath; //不生成缩略图则返回原图 } //如果是图片,检查是否需要打水印 if (IsWaterMark(fileExt) && isWater) { switch (this.siteConfig.watermarktype) { case 1: WaterMark.AddImageSignText(newFilePath, newFilePath, this.siteConfig.watermarktext, this.siteConfig.watermarkposition, this.siteConfig.watermarkimgquality, this.siteConfig.watermarkfont, this.siteConfig.watermarkfontsize); break; case 2: WaterMark.AddImageSignPic(newFilePath, newFilePath, this.siteConfig.watermarkpic, this.siteConfig.watermarkposition, this.siteConfig.watermarkimgquality, this.siteConfig.watermarktransparency); break; } } //处理显示的地址 string imageUrl = siteConfig.imagespath; newFilePath = imageUrl + strUrl + newFilePath.Substring(newFilePath.LastIndexOf("/") + 1); newThumbnailPath = imageUrl + strUrl + newThumbnailPath.Substring(newThumbnailPath.LastIndexOf("/") + 1); //处理完毕,返回JOSN格式的文件信息 return "{\"status\": 1, \"msg\": \"上传文件成功!\", \"name\": \"" + fileName + "\", \"path\": \"" + newFilePath + "\", \"thumb\": \"" + newThumbnailPath + "\", \"size\": " + fileSize + ", \"ext\": \"" + fileExt + "\"}"; } catch { return "{\"status\": 0, \"msg\": \"上传过程中发生意外错误!\"}"; } } ``` ``` 都是以http流来接收图片的,是什么原因呢,求解

Error:(35, 30) 错误: 找不到符号

我自定义了一个Convert,代码如下 public final class MyConvert extends Converter.Factory { private final Gson gson; public static MyConvert create(Gson gson) { return new MyConvert(gson); } public static MyConvert create(){ return create(new Gson()); } public MyConvert(Gson gson) { this.gson = gson; } @Override public Converter<ResponseBody, ?> responseBodyConverter(Type type, Annotation[] annotations, Retrofit retrofit) { TypeAdapter<?> adapter=gson.getAdapter(TypeToken.get(type)); return super.responseBodyConverter(type, annotations, retrofit); } } TypeAdapter<?> adapter=gson.getAdapter(TypeToken.get(type)); 这句代码死活编译不过去,报错信息如下: Error:(35, 30) 错误: 找不到符号 符号: 方法 getAdapter(TypeToken<CAP#1>) 位置: 类型为Gson的变量 gson 其中, CAP#1是新类型变量: CAP#1从?的捕获扩展Object 困扰了好几天,求大神帮忙解答~~~~

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

Java校招入职华为,半年后我跑路了

何来 我,一个双非本科弟弟,有幸在 19 届的秋招中得到前东家华为(以下简称 hw)的赏识,当时秋招签订就业协议,说是入了某 java bg,之后一系列组织架构调整原因等等让人无法理解的神操作,最终毕业前夕,被通知调往其他 bg 做嵌入式开发(纯 C 语言)。 由于已至于校招末尾,之前拿到的其他 offer 又无法再收回,一时感到无力回天,只得默默接受。 毕业后,直接入职开始了嵌入式苦旅,由于从未...

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

@程序员:GitHub这个项目快薅羊毛

今天下午在朋友圈看到很多人都在发github的羊毛,一时没明白是怎么回事。 后来上百度搜索了一下,原来真有这回事,毕竟资源主义的羊毛不少啊,1000刀刷爆了朋友圈!不知道你们的朋友圈有没有看到类似的消息。 这到底是啥情况? 微软开发者平台GitHub 的一个区块链项目 Handshake ,搞了一个招募新会员的活动,面向GitHub 上前 25万名开发者派送 4,246.99 HNS币,大约价...

再不跳槽,应届毕业生拿的都比我多了!

跳槽几乎是每个人职业生涯的一部分,很多HR说“三年两跳”已经是一个跳槽频繁与否的阈值了,可为什么市面上有很多程序员不到一年就跳槽呢?他们不担心影响履历吗? PayScale之前发布的**《员工最短任期公司排行榜》中,两家码农大厂Amazon和Google**,以1年和1.1年的员工任期中位数分列第二、第四名。 PayScale:员工最短任期公司排行榜 意外的是,任期中位数极小的这两家公司,薪资...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

华为初面+综合面试(Java技术面)附上面试题

华为面试整体流程大致分为笔试,性格测试,面试,综合面试,回学校等结果。笔试来说,华为的难度较中等,选择题难度和网易腾讯差不多。最后的代码题,相比下来就简单很多,一共3道题目,前2题很容易就AC,题目已经记不太清楚,不过难度确实不大。最后一题最后提交的代码过了75%的样例,一直没有发现剩下的25%可能存在什么坑。 笔试部分太久远,我就不怎么回忆了。直接将面试。 面试 如果说腾讯的面试是挥金如土...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

win10暴力查看wifi密码

刚才邻居打了个电话说:喂小灰,你家wifi的密码是多少,我怎么连不上了。 我。。。 我也忘了哎,就找到了一个好办法,分享给大家: 第一种情况:已经连接上的wifi,怎么知道密码? 打开:控制面板\网络和 Internet\网络连接 然后右击wifi连接的无线网卡,选择状态 然后像下图一样: 第二种情况:前提是我不知道啊,但是我以前知道密码。 此时可以利用dos命令了 1、利用netsh wlan...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

程序员写出这样的代码,能不挨骂吗?

当你换槽填坑时,面对一个新的环境。能够快速熟练,上手实现业务需求是关键。但是,哪些因素会影响你快速上手呢?是原有代码写的不够好?还是注释写的不够好?昨夜...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

Python爬虫,高清美图我全都要(彼岸桌面壁纸)

爬取彼岸桌面网站较为简单,用到了requests、lxml、Beautiful Soup4

立即提问
相关内容推荐