My coworker had a document that had around 30 comments and when she'd click on the comment to delete it, Word 2007 would crash. She mentioned that the comment targets somehow were erased and the comments were orphaned but still in the document.
Word has a recovery mode that did not work. I tried copy/pasting to a new document which did not work. Even tried using a VBA macro to delete a comment, then altered it to select and delete these other comments. That didn't work either.
I know Word 2007 uses the new .docx format, which is really just a zip file container. So I unzipped the .docx file, dug around in the supporting XML files, and found two files. There is a document.xml and a comments.xml and inside the comments.xml file is an ID in each node that the document.xml file references. Pretty simple layout.
In the document.xml file, I searched for "w:comment" and found hits on nodes named
<w:commentRangeStart w:id="3" />
<w:commentRangeEnd w:id="3"/>
<w:commentReference w:id="3"/>
Those nodes match the comments.xml document that has
<w:comment w:id="3">
Furthermore, while searching through the document.xml file, the IDs for problematic comments just happened to have
<w:commentReference w:id="3"/>
but not
<w:commentRangeStart w:id="3" />
<w:commentRangeEnd w:id="3"/>
So... Remove the broken references in document.xml and now there are fully orphaned items in comments.xml so remove those nodes as well. Save all docs, then rezip the folder and rename to .docx
The doc opens fine, and Word 2007 no longer crashes :) Woohoo.
Monday, September 12, 2011
Thursday, September 1, 2011
Ensure deploys are not in debug mode
The <deployment retail=”true”/> Switch in Machine.config
If you are a server administrator and want to ensure that no one accidentally deploys an ASP.NET application in production with the <compilation debug=”true”/> switch enabled within the application’s web.config file, one trick you can use with ASP.NET V2.0 is to take advantage of the <deployment> section within your machine.config file.
Specifically, by setting this within your machine.config file:
<configuration>
<system.web>
<deployment retail=”true”/>
</system.web>
</configuration>
You will disable the <compilation debug=”true”/> switch, disable the ability to output trace output in a page, and turn off the ability to show detailed error messages remotely. Note that these last two items are security best practices you really want to follow (otherwise hackers can learn a lot more about the internals of your application than you should show them).
Setting this switch to true is probably a best practice that any company with formal production servers should follow to ensure that an application always runs with the best possible performance and no security information leakages. There isn’t a ton of documentation on this switch – but you can learn a little more about it here.
Tuesday, August 30, 2011
WebResource.axd returns 404 and then starts working after a while on it's own
Original question that I posted:
http://stackoverflow.com/questions/6902650/webresource-axd-wont-update
http://forums.asp.net/t/1711550.aspx/1?WebResource+axd+returns+404+and+then+starts+working+after+a+while+on+it+s+own
We have a library of common controls, and I'm attempting to steer towards using embedded resources in it for images, JS, and CSS. It seems that upon each deploy to TEST/PROD, there is a window of time where WebResource.axd is returning a 404. After that window of time expires, suddenly the page starts serving out content properly. On my local DEV machine it seems that there are times when I can compile and reload a page that is using embedded resources, and it immediately shows a difference. Other times it responds like there is a cache waiting to expire.OK, WOW... FINALLY stumbled a solution. Ready? This is going to be a long one :)
Things I've tried:
- browsing from different machines to rule out local caching
- iisreset
- net stop w3svc
- delete temp files from C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files and C:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files
- killing the inetinfo.exe process
- killing the w3wp.exe process
- disabling IIS Output Caching
- copying the URL and adding in an extra false querystring parameter to mimic a new page request
- pressing Ctrl-F5 :)
It seems rebooting fixes the issue.
My google kung-fu has diluted results filled with everyone's answer to check the namespace. I am confident the namespace is correct. After a while the resource will start serving out properly and the correct version. And if it DOES serve at some point, it seems logical to me that the namespace must be correct.
Any ideas? What other information can I provide?
Thanks,
James
Michigan, USA
While trying to get more information, I load Fiddler and I'm looking at the headers... when I come across
this standard .NET error (edited):
<html>WHOA... there's a commented stack trace that is buried in the page?!?! After a quick Google search and I come across a link to http://stackoverflow.com/questions/1096793/system-web-httpexception-this-is-an-invalid-script-resource-request and on that page I stumble across this comment by Rob Levine (http://stackoverflow.com/users/134754/rob-levine):
<head>
<title>The resource cannot be found.</title>
[snip]
</head>
<body bgcolor="white">
<span><H1>Server Error in '/' Application.<hr width=100% size=1 color=silver></H1>
<h2> <i>The resource cannot be found.</i> </h2></span>
[snip]
<b>Version Information:</b> Microsoft .NET Framework Version:4.0.30319; ASP.NET Version:4.0.30319.1
</font>
</body>
</html>
<!--
[HttpException]: This is an invalid webresource request.
at System.Web.Handlers.AssemblyResourceLoader.System.Web.IHttpHandler.ProcessRequest(HttpContext context)
at System.Web.HttpApplication.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute()
at System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously)
--><!--
This error page might contain sensitive information because ASP.NET is configured to show verbose error messages
using <customErrors mode="Off"/>. Consider using <customErrors mode="On"/> or <customErrors
mode="RemoteOnly"/> in production environments.-->
Believe it or not, if your dlls have embedded resources in them, and they are dated in the future this will happen (if you ever compile dlls in the UK and then immediately deploy them to US web servers you'll be well aware of this issue!). I can't remember the event log error this shows, but would know if I saw it - and it is not immediately obvious.That is exactly the situation... I compile in Eastern Time, then deploy to Rackspace in Central Time. After about an hour the resources begin to load again... it makes sense... the time stamps catch up!
Sunday, July 17, 2011
The page has one or more asp:Content controls that do not correspond with asp:ContentPlaceHolder controls in the Master Page.
I kept getting this error in the design view:
The page has one or more <asp:Content> controls that do not correspond with <asp:ContentPlaceHolder> controls in the Master Page.A few Google searches, this is what I found to work for me:
Settinghttp://forums.asp.net/t/1302708.aspx
<title></title>
instead of
<title />
solved the problem.
Friday, July 1, 2011
Skype in the Windows 7 taskbar
Try searching Google to see how to get rid of the Skype icon off the taskbar. There are mostly results that instruct changing the shortcut's Compatibility mode to SP2. That sounds clever but Skype itself directly supports this.
Open Skype...
Click Tools in the menu bar...
Click the Options menu item...
a new window will open, click the Advanced button on the bottom left of the new window...
Skype should have a checkbox entry that says
"Keep Skype in the taskbar while I'm signed in."
Open Skype...
Click Tools in the menu bar...
Click the Options menu item...
a new window will open, click the Advanced button on the bottom left of the new window...
Skype should have a checkbox entry that says
"Keep Skype in the taskbar while I'm signed in."
Wednesday, June 29, 2011
UpdatePanel isn't working, ScriptManager seems to not be rendering?
Where to start... I was using RadAjaxPanel with a standard ListBox and AutoPostBack enabled. After clicking the new ListItem, the event would not fire. Turns out that the RadAjaxPanel I was using was out-of-date that I believe was targeting the .NET 2.0 Framwork. This would be a good time to explore using the standard .NET 4.0 UpdatePanel.
I found several demos that worked on their own in a new 4.0 project. However when adding the demo code to our existing project, it didn't work. The project had been updated from 1.1, to 2.0 to now 4.0 and it might have even been upgraded from 1.0 to 1.1 - it's been around a while now.
I noticed that the demo's rendered HTML had a few things different from our implimentation of the demo. Where the ScriptManager was at, the demo had:
and a LOT more google searching, led me to checking over the Web.Config for proper entries:
Turns out I was missing this:
I found several demos that worked on their own in a new 4.0 project. However when adding the demo code to our existing project, it didn't work. The project had been updated from 1.1, to 2.0 to now 4.0 and it might have even been upgraded from 1.0 to 1.1 - it's been around a while now.
I noticed that the demo's rendered HTML had a few things different from our implimentation of the demo. Where the ScriptManager was at, the demo had:
<script type="text/javascript">
//<![CDATA[
Sys.WebForms.PageRequestManager._initialize('scriptMgr', 'form1', ['tupdatePnl','updatePnl'], [], [], 90, '');
//]]>
</script>
and a LOT more google searching, led me to checking over the Web.Config for proper entries:
Turns out I was missing this:
<pages controlRenderingCompatibilityVersion="3.5" clientIDMode="AutoID">
<controls>
<add tagPrefix="asp" namespace="System.Web.UI" assembly="System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>
</controls>
</pages>
and this had to be removed:
<xhtmlConformance mode="Legacy"/>
Tuesday, June 28, 2011
View DOM Source
Often times the original View Source in a web browser is not sufficient for developers due to AJAX, jQuery, etc.. The developer tools in IE 8 (access by pressing F12) are pretty useful, but today I stumbled on View DOM Source.
Access it by View, Source, DOM (Page) - or press Ctrl+G
Access it by View, Source, DOM (Page) - or press Ctrl+G
Subscribe to:
Posts (Atom)