Решење за проблем: “ФилеНотФоундЕкцептион” Витх Ми Феатуре Рецеивер.

I was working on a feature last week that would add some event receivers to a specific list instance. (Ја блог мало о том списку пријемник овде).

Коришћење командне линије, Могу да инсталирате функцију без грешке (али види доле за скривене грешке). When I tried to deploy the feature on the site, MOSS complained of a "FileNotFoundException" грешка. This blog entry describes how I solved it.

То је грешка која Мос ми је показао у веб претраживачу:

Feature ‘b2cb42e3-4f0a-4380-aaba-1ef9cd526f20’ could not be installed because the loading of event receiver assembly "xyzzyFeatureReceiver_0" није успело: Систем.ИО.ФилеНотФоундЕкцептион: Could not load file or assembly ‘xyzzyFeatureReceiver_0’ или један од његових зависности. Систем не може да пронађе наведену датотеку.
Филе наме: ‘xyzzyFeatureReceiver_0’
at System.Reflection.Assembly.nLoad(АссемблиНаме филеНаме, Стринг цодебасе, Докази ассемблиСецурити, Скупштина лоцатионХинт, СтацкЦравлМарк& стек земљишта, Булова тхровОнФилеНотФоунд, Булова форИнтроспецтион)
at System.Reflection.Assembly.InternalLoad(АссемблиНаме ассемблиРеф, Докази ассемблиСецурити, СтацкЦравлМарк& стек земљишта, Булова форИнтроспецтион)
at System.Reflection.Assembly.InternalLoad(Стринг ассемблиСтринг, Докази ассемблиСецурити, СтацкЦравлМарк& стек земљишта, Булова форИнтроспецтион)
at System.Reflection.Assembly.Load(Стринг ассемблиСтринг)
at Microsoft.SharePoint.Administration.SPFeatureDefinition.get_ReceiverObject()
ВРН: Скупштина обавезујућа је евидентирање искључен.
Да би омогућили склапање бинд евидентирање неуспех, подесите вредност регистратора [ХКЦУ Софтваре Мицрософт Фусион!ЕнаблеЛог] (ДВОРД) на 1.
Приметити: Постоје неки перформанс казна повезана са скупштине везују сече отказа.
Да бисте искључили ову функцију, уклоните вредност регистратора [ХКЦУ Софтваре Мицрософт Фусион!ЕнаблеЛог].

Решавање проблема са Виндовс СхареПоинт Сервицес.

Знам како да намерно изазове ту грешку: don’t install the assembly in the GAC. Али, it was in the GAC. I normally install assemblies into the GAC by dragging them into the c:\windows\assembly folder using windows explorer. I’ve never felt 100% удобно да ради, јер сам увек мислила да је постојао гацутил разлогом … so I tried that. It made no difference.

Претражио сам интернетс и нашао овај пост: http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=2243677&SiteID=1

Постер десило да се користи исти корен део кода (Од унутра ВСС књиге са ове листе) so that was a hopeful sign. Међутим, Предлог украшавање скупштине са [монтажа: ] directive didn’t make sense to me. I tried it anyway and I was right. It made no difference.

Then I noticed that my class definition was not public. I made it public and that made no difference.

Следећи, I went to the trouble of enabling the "assembly bind failure log" (након корисне и тачне упутствима) and this is where things started to get interesting. That log shows me that the runtime is searching everywhere on that server for my assembly. It even appears to be searching for it in my medicine cabinet. Али … неће га потражите у ГАЦ.

I put on my winter jacket and go searching the Internets again and find that someone has had this problem too. The lengthy discussion in that posting peters off into nothing and I can’t find a solution.

I move my assembly into one of the places the log claims it’s searching and I make a little more progress. I’m rewarded with a new error in the browser when I try to activate the feature:

Failed to create feature receiver object from assembly "xyzzyFeatureReceiver_0", type "Conchango.xyzzyFeatureReceiver" за функцију б2цб42е3-4ф0а-4380-Ааба-1еф9цд526ф20: Систем.АргументНуллЕкцептион: Вредност не може бити нула.
Параметар име: тип
at System.Activator.CreateInstance(Тип, Булова нејавне)
at System.Activator.CreateInstance(Тип)
at Microsoft.SharePoint.Administration.SPFeatureDefinition.get_ReceiverObject()

Решавање проблема са Виндовс СхареПоинт Сервицес.

Време је за последњи пут на интернетс!

Овај пут сам сазнао, предвидиво довољно, that MOSS issues this error because the assembly is not in GAC.

Ја желим да се нешто позитивно из ове и покушајте да осетите мало похвалити да сам направио Бегунац од МСИЛ склопова, but it’s not working. I’m just plain annoyed. I find myself muttering "chicken or the egg" под мој дах.

I finally decide to punt. I create an entirely new project and copy/paste the code from the incredible-cloaked-from-the-GAC-assembly non-working project over to this new project. (I look for a build flag called something like "hide from assembly binding if installed in the GAC" али не могу наћи).

Ја инсталирате функцију и активирати га и … ради! Тако, после свега што, I had to basically ‘reboot’ my project. То је још један разлог зашто мрзим рачунаре.

I did learn something useful from this. I had been installing features using the stsadm command line all day long and been using the "-force" option out of habit. For some reason, I did not use the -force option when I installed the new project. Овај пут, Ја сам заправо урадио, truly forget to copy this new project’s assembly into the GAC. Као резултат тога, I received that "FielNotFoundException" грешка. Овај пут, Добио сам је од стсадм, not when I tried to activate the feature via the web browser. Тако, -force actually plays two roles. It allows you to re-install an existing feature. It also allows you to install a buggy feature that cannot work at runtime by suppressing the error. It probably says as much in the help somewhere but I never noticed it.

</крај>

Недеља смешно: Топ 10 Начини да изнервира своју жену

  1. Купите броколи када знате већ има више него довољно у фрижидеру.
  2. Go for a run. Cool off. Take off clean pillow case and replace with T-shirt. Cover with clean pillow case.
  3. Када возите, питају да ли треба да идемо у погрешном правцу доле једносмерној улици.
  4. За 15 године, сваке недеље да жена сугерише иде у музеј, Екпресс изненађење да музеји су отворени на недељу.
  5. За 15 године, occasionally suggest going to the local book store on Sunday. Express surprise that they are not open on Sunday’s (хвала пуно Блуе Закони!).
  6. Коришћење 20 указује да се ураде 3 point turn.
  7. На хладном поподнева почетком јесени, walk into the room and turn on the A/C. Complain that it’s cold. When wife says, "then why did you turn that on, глуп" и устаје да га искључите, grab the warm spot she had on the couch. Bonus points if she does not realize you did it until much later.
  8. Отворите конзерву беле дугорепка укусног туна и једу га директно из конзерве, у кревету, ноћу.
  9. Иди у кухињу, а жена се једе вечеру, отвори фиоку есцајг и гурајте прибор док око супруге крике, "what are you looking for!"
  10. На пријему нових пословних картица, тајно ставите их све по кући: Испод кревета, у јастук случајевима, унутар шоље за кафу, у ташни, у џеповима капута, ауто глове коморе, шпајз — anywhere you can think of.
  11. Напиши Блог о својој жени.
  12. Пробудити.
  13. Када хода улицама Њујорка, be on the alert for "crusty" objects on the ground. Имајући у виду посебне ваше супруге страхове, до доле као да се један покупи се и питајте, "hmm, Питам се шта је то?" (Be prepared for wife to body slam you as if she’s a secret service agent protecting the President from a sniper or you’ll find yourself laying on your back on the sidewalk).
  14. Drive twice around a parking lot looking for space. You know you’ve really hit pay dirt when your son in the back seat yells, "Oh no! He’s doing it поново!"
  15. Write "top 10" lists that don’t have 10 ставке.

===

Bonus wife joke:

Two male co-workers go out to lunch. One of them tells the other, "I let loose an embarrassing Freudian slip the other night."

"A Freudian slip? What’s that?"

"Well, when we finished eating, the waitress came by and asked how we liked our meals. I meant say, ‘I loved the chicken breast’ but instead I said ‘I loved your breasts’. I was so embarrassed."

"Ah," his co-worker replied. "I had the same thing happen to me this weekend with my wife. We were eating breakfast I meant to ask her to pass the butter, but instead I screamed at her, ‘You ruined my life!’"

</крај>

Тецхнорати Тагс:

ИД догађаја 1023: “Виндовс не може да учита прошириви Бројач МССЦНТРС ДЛЛ”

УПДАТЕ (04/08/08): I seem to have solved this problem. From the command line, I ran "c:\виндовс систем32 лодцтр / Р" године по уласку говори о проблемима и ИнсталлСхиелд који изгледа да су решили да за мене.

Приметио сам да у последње време, my desktop/server fan never turns off. I know it used to turn off. I took a moment to check it out noticed that the a VMware process was running a consistent 20% utilization on one of the CPU’s. I checked the event log and saw these errors in the application log happening dozens of times per minute:

Виндовс не може да учита прошириви цоунтер УГатхерер ДЛЛ, Први ДВОРД података у одељку Виндовс је код грешке.

Виндовс не може да учита прошириви цоунтер УГТХРСВЦ ДЛЛ, Први ДВОРД података у одељку Виндовс је код грешке.

Виндовс не може да учита прошириви Бројач МССЦНТРС ДЛЛ, Први ДВОРД података у одељку Виндовс је код грешке.

Ако сам бушилица у детаље једне од тих порука, Ја ово:

Извор: Перфлиб

Тип: Грешка

Категорија: Ниједан

ИД догађаја 1023

I did some research and there was some indication it could be a permission problem in terms of access to the DLLs in question. I played around with that stuff but could not affect things in a positive way so I gave up on that.

ВМваре су ме закерање о вршењу исправку за дуже време, па сам записао верзију сам инсталирао (apparently "1.0.1 build 29996") and did the update. This upgraded me to v1.04. Нажалост, није решила проблем.

I can stop the insane number of messages going to my application log if I shut down a service named "VMware Authorization Service". This prevents me from using the VMware software, тако … not such a great option.

Домаћин оперативни систем Виндовс КСП 64 бит.

Ја не мислим да је то увек било, али ја се не сећам да је неки посебан догађај можда довело до тога.

Зато мрзим рачунаре.

</крај>

Тецхнорати Тагс:

Брз & Лако: Преименовање отпремљене датотеке Коришћење СхареПоинт Објецт Модел преко Евент Рецеивер

УПДАТЕ: This works but there are significant limitations which are described in the comments. This may still be useful in some cirumstances.

УПДАТЕ 2: У мом тренутном пројекту, users always upload documents. Као резултат тога, I don’t run into a problem where MS Word is running and thinks that the file was renamed on it. I did run into a problem, "the file was modified by someone else" and solved this via a simple semaphore type flag. Users need to change a meta data field from its default value to something else. The itemupdated() пријемник тражи важећу вредност пре него што се заправо обавља преименовати и од тада, I have not had any problems. Your mileage may vary.

I have a client requirement to change the name of files uploaded to a specific document library to conform with a particular naming convention. The API does not provide a "rename()" метод. Уместо тога, користимо "MoveTo(…)". Here is a minimal bit of code to accomplish this:

 јавност заменити воид ИтемАддед(СПИтемЕвентПропертиес Некретнине)
        {
            СПФиле ф = пропертиес.ЛистИтем.Филе;

            ф.МовеТо(пропертиес.ЛистИтем.ПарентЛист.РоотФолдер.Урл + "/xyzzy.doc");
            ф.Упдате();

        }

The only tricky bit is the "properties.ListItem.ParentList.RootFolder.Url". The MoveTo() method requires a URL. That mashed up string points me to the root folder of my current document library. This allows me to avoid any hard coding in my event receiver.

То је више користан верзија која ради исту ствар, but assigns the name of the file to "Title":

 јавност заменити воид ИтемАддед(СПИтемЕвентПропертиес Некретнине)
        {
            ДисаблеЕвентФиринг();

            // Додели наслов ове ставке на име фајла самог.
 // НАПОМЕНА: Овај задатак се мора одвијати пре него што измените саму датотеку.
 // Позивање упдате() на СПФиле изгледа да поништи својства у
 // неки смисао.  Updates to "Title" није до те промене (и ажурирање() позвати)
 // су се преселили испред промена имена датотеке.
            пропертиес.ЛистИтем["Title"] = Пропертиес.ЛистИтем.Филе.Наме;

            пропертиес.ЛистИтем.Упдате();

            СПФиле ф = пропертиес.ЛистИтем.Филе;

            // Набавите продужење датотеке.  Треба да се касније.
 ниска спфилеЕкт = нови Филе Инфо(ф.Наме).Продужетак;

            // Преименујте датотеку ИД ставке листе и употребите екстензију да
 // да део нетакнут.
            ф.МовеТо(пропертиес.ЛистИтем.ПарентЛист.РоотФолдер.Урл +
                "/" + пропертиес.ЛистИтем["ID"] + спфилеЕкт);

            // Цоммит тај потез.
            ф.Упдате();

            ЕнаблеЕвентФиринг();
        }

Форум Дискусија: Примена најбоље праксе у Поштовање нетривијално МОСС средине

Момак, "Mark", has started up a potentially interesting newsgroup discussion focusing on "establishing excellent SharePoint Governance from the start" за 35,000 корисничко окружење.

Дискусија је овде: http://groups.google.com/group/microsoft.public.sharepoint.portalserver/browse_thread/thread/6d9a738d981af772/1c390b15c5407db6?#1c390b15c5407db6

Поп овамо и доприносе!

</крај>

Прилагођена УРЛ адреса Акција неће приказивати на Нова функција

I’m still in the habit of crafting my feature XML files by hand since it’s all quite new to me. I don’t want to rely on a front-end tool that does stuff I don’t understand (Он је рекао како је написао један блог унос помоћу алатке које не разуме).

Данас, I was trying to add a custom action to the site settings but it just wouldn’t show up. I could install the feature and see it in the site features, али кад сам га активирао (без грешке) то једноставно не би појавила на падајућем менију.

I finally realized that I misspelled "SharePoint" Локација у атрибуту <ЦустомАцтион> чвор. This is the bad elements.xml file:

<?КСМЛ верзија="1.0" кодирање="УТФ-8" ?>
<Елементи КСМЛнс="хттп://сцхемас.мицрософт.цом / СхареПоинт /">
  <ЦустомАцтион
 Ид="СитеАцтионсТоолбар"
 ГроупИд="СитеАцтионс"
 Локација="Мицрософт.Схарепоинт.СтандардМену"
 Секвенца="100"
 Наслов="Здраво!"
 Опис="Прилагођено Мени Акција додао преко функције."
 УРЛ слике="_лаиоутс / имагес / менупрофиле.гиф">

    <УрлАцтион Сајт="хттп://ввв.киззи.цом"/>

  </ЦустомАцтион>
</Елементи>

Добар:

<?КСМЛ верзија="1.0" кодирање="УТФ-8" ?>
<Елементи КСМЛнс="хттп://сцхемас.мицрософт.цом / СхареПоинт /">
  <ЦустомАцтион
 Ид="СитеАцтионсТоолБар"
 ГроупИд="СитеАцтионс"
 Локација="Мицрософт.СхареПоинт.СтандардМену"
 Секвенца="100"
 Наслов="Здраво!"
 Опис="Прилагођено Мени Акција додао преко функције."
    >
    <УрлАцтион Сајт="хттп://ввв.киззи.цом"/>
  </ЦустомАцтион>
</Елементи>

That one took me a good two hours to figure out 🙂

Ја утеху у чињеници да ће једног дана у будућности, Ја ћу бити у стању да каже са уверењем, "back in the day, Морао сам да ходам три миље до брда у снегу (бос!) in order to deploy a custom feature to MOSS. You kids, Ви не знате како је лако да га! Get off my lawn!"

Не може да чека.

</крај>

Тецхнорати Тагс: ,

Блог Статс

I thought some people might be interested in my blog’s statistics. You can use mine as a benchmark to compare your own.

I’m running my blog on windows live spaces. They collect stats for me and I don’t know any way to control that. It’s good as far as it goes, but it’s fairly limited in that I can’t do much actual analysis with it. I’d love, на пример, to be able to generate a listing of my most frequently hit posts but I can’t do that without a prohibitive manual process. If someone knows better, молим вас реците ми.

Ливе Спацес статус ми: укупна хитова за дан, total hits for the week and total hits since day zero. It also tells me what people did to get to my blog (e.g. гоогле, МСДН Форум линк, итд).

На неки начин, a "hit" је очигледна. Ако читате ову реченицу одмах, смо скоро сигурно сте регистровани као један хит.

RSS is a little confusing. On one hand, I see individual RSS hits all day long. Али, I also see RSS "sweeps". A sweep is when I see 20 или 30 RSS hits all within a one or two second window. I assume these are automated things like google checking in on my site, прегледачи можда других људи … not sure. They are definitely some kind of automated process. I cannot tell, међутим, how many of my total hits are automated and how many have an actual human on the other side. I would guess at least 100 хитова дневно су аутоматизовани.

На на бројеве!

Написао сам свој први блог унос 27. јула, 2007.

, Отприлике сам написао 60 блога од тада, више од 50 који се директно односе на СхареПоинт.

Почео сам да пратите од мојих хитова у табели свакодневно на крају септембра.

Месечни Почиње:

Прва недеља: Укупно прегледа
Октобар 1,234
Новембар 2,162
Децембар 3,071
Јануар 2008 4,253

Укупно по месеца

Месец Укупно прегледа
Октобар 6,620
Новембар 11,110
Децембар 13,138

Висока вода марака

Тип Укупно прегледа
Најбољи дан 958
Најбоље недеља 4,253
Укупно прегледа од првог Зеро 42,438

Ја сам заинтересован за друге’ stats. If you care to share yours in the comments, молим вас!

</крај>

Тецхнорати Тагс:

Сундаи Морнинг Фунни: “Да, да, да. Блах, бла, бла.”

Пре око шест година, мој четворогодишњи син и ја смо били на спрату гледао Дисцовери Цханнел "shark attacks" посебан (Могуће овај). He was very young at the point and I was always worried what he might see on a show like this and how he might take it. I didn’t want him to develop, на пример, било који специјалне страхови воде или наговорити нешто неприкладно својим пријатељима и можда изазвати своју мрежу пријатеља беба да се срушити.

Discovery handles these kinds of subjects very well. It’s not about creating a страх од нешто, but rather to show how unusual it is for sharks to attack humans.

Тако, we’re watching it and there is this one particularly scary attack involving a small girl. As Discovery is building the drama of the attack, мој син (који је увек био изузетно нервозан ионако), is getting very excited. I make some noises about how unusual it is for sharks to attack people, and how bad the poor girl must feel. I’m trying to explain that people recover from these events and become stronger for it. Међутим, I had misinterpreted his excitement. He was not worried about the girl at all. Уместо тога, док цлаппинг руке, он ми каже, "The sharks love it! It’s terrific. It’s wonderful. Its a DREAM COME TRUE!"

Мислио сам да је смешан, but also very disturbing. У једну руку, Било ми је драго — чак и мало поносан — да би могао да има јака осећања емпатичан, cross-species though they may be. As humans, we need to develop our "empathic muscles" тако говоре, или ћете завршити као овај момак 🙂 On the other hand, he was feeling cross-species empathy toward a species who was exhibiting behavior inimical to his own. I was really struggling with this when the narrator used the word "paradigm". My son picked up on that and asked me what that meant.

То није тако лако реч да опише на четворогодишњи, but I gave it a try. When I think of the word "paradigm", Томас Кун is never far from my thoughts. Прочитао сам Структура научних револуција назад на Лафајет и на боље или на горе, the word "paradigm" is pregnant with extra meaning for me. (Sort of like the word "contact" после саслушања филма Телефон глас реци ми где сам могао да видим тај филм [Мислио сам да је књига била боља]; Ја увек кажем себи, "CONTACT!" whenever I see or hear someone say "contact").

У сваком случају, Покушавам да му објасним Кухниан дефиницију, that it’s "a historical movement of thought" and that it’s a "way of thinking with a number of built-in assumptions that are hard to escape for people living at that time." Наравно, Ви не можете разговарати као са четири годишња, so I’m trying to successively define it to smaller pieces and feeling rather proud of myself as I do so. (Управо сам Знао да неко изван колеџа би марио да сам прочитао Кухн!).

I’m just warming to the task when he interrupts me. Waving his hand у мом општем правцу и никада не скидајући поглед са другог бруталном нападу ајкуле, Он само каже, "Yeah, да, да. Блах, бла, blah.".

So much for that 🙂

У том тренутку, Одлучио сам да побегнем, реторички говорећи, одмарати се, и уживати гледајући ајкуле нападају људе са сином.

</крај>

Тецхнорати Тагс:

Укључи преглед Преглед основу корисничког ИД Ин Ан ИнфоПатх обрасцу

Је Развили смо ИнфоПатх образац са више приказа да подржи нову изнајмљивање / on-boarding process. When the company hires a new person, ИТ одељење и друге групе треба да предузме акцију (подесите плате, омогући приступ одговарајућим апликацијама, пронађите радни сто, итд). We use on form but a different view of the form for each of those functions.

At this company, most of the people involved in the business process are IT-savvy, so when they access the form, their default view is a "menu" view with buttons that direct them to their specific function. Међутим, we needed to simplify things for the new hire’s direct manager. This person should not see any of the IT related stuff. Заправо, she should see just one view of the form and not even have an option to see the other views.

У нашем случају, that direct manager’s account is directly tied to the form courtesy of a contact selector (which I am always wanting to call a "people picker" for some reason).

The steps are as follows:

1. In design mode, go to Tools -> Форма Оптионс -> Open and Save.

2. Select "rules".

3. Create a new rule whose action is "switch to view" and whose condition leverages the userName() функција.

усерНаме() returns the "simple" user name without the domain. If I log into SharePoint with credentials "domain\pagalvin", усерНаме() returns "pagalvin".

The contact selector provides three bits of information for a contact. The "AccountID" portion is most useful for this scenario. The only thing that makes this even a little bit of challenge is that the contact selector (in my environment anyway) returns the domain and user ID, as in "domain\pagalvin". This prevents us from doing a straight-forward equality condition since AccountID ("domain\pagalvin") will never equal userName() ("pagalvin").

We can get around this using the "contains" operator: AccountID contains userName().

We can take it further and pre-pend a hard-coded domain in front of the userName() function to get our equality check and eliminate the risk of a false positive on the contains operator.

We would have REALLY like to automatically switch view for other users based on their AD security group membership. На пример, when a member of the "IT Analytics" group accesses the form, automatically switch to the IT Analytics view. We didn’t have time to implement it, but my first thought is to create a web service that would have a method like "IsMemberOfActiveDirectorySecurityGroup", pass it the userName() and return back true or false. Does anyone have any other, more clever idea? Is there any SharePoint function we can leverage from InfoPath to make that determination?

</крај>

Тецхнорати Тагс:

Случајно Додавање кода на ИнфоПатх образац; Намерно Уклањање

Када радите са тастерима на обрасцу, we often add rules. You access the rules editor from the properties of the button.

Када кликнете око брзо, it’s easy to accidentally click on "Edit Form Code" instead of "Rules …".

Први пут сам ово урадио, I canceled out of the code editor. Међутим, када сам покушао да објаве начин касније мало, it required that I publish as an "Administrator-approved form template (напредан)". I didn’t actually do any programming and I absolutely didn’t want to go through an unnecessary approval process. I was in a bit of panic at the time due to time constraints. To get past it, I simply restored a previous backup and continued. I had recently seen some blog posts about people going into the form’s XML to tweak things and I was afraid I would have to do something similar.

Данас, I did it again. Овај пут, Имао сам мало више времена на рукама и открили да лако можете да опозовете.

Иди на:

Алати -> Форма Оптионс -> Програмирање: "Remove Code"

То не би много лакше него да.

</крај>

Тецхнорати Тагс: ,