Kateqoriya Arxivləri: SharePoint İnkişaf

Simple İzahı: “Dəyər gözlənilən diapazona düşən deyil.”

UPDATE: An anonymous poster left a great comment about internal names. Be sure to read it.

Tədbirdə alıcıları və digər kodu ilə iş zaman olduğu obyekt model vasitəsilə istinadlar SharePoint siyahısı maddələr, Mən tez-tez zamanı bu səhv yaradan səhvlər:

Xyzzy hata yüklənməsi və çalışan hadisə qəbuledici Conchango.xyzzyEventReceiver, Version = 1.0.0.0, Mədəniyyət = neytral, PublicKeyToken = 0dc50a750396c3ac. Additional information is below. : Value does not fall within the expected range.

I think this is a fairly generic error that is potentially caused many different ways. Lakin, one simple explanation is that I’m referencing a field incorrectly. If the name of the field is "Due Date", Mən hadisə alıcı bu kimi istinad olunmalıdır:

properties.ListItem["Due Date"]

Sahəsində bir sened mən yanlış işi orfoqrafik səhv etmək və ya istifadə, SharePoint generates the above mentioned runtime error. Məsələn, bu səhv:

properties.ListItem["due Date"]

</son>

Blog abunə.

Technorati Tags:

Sürətli & Asan: Qovluq yaradın və məzmun Tipi Təyin (Və ya, Sizin KPIs və onların çox yeyin)

Ətrafında bir KPI problem işləmək üçün Burada haqqında yazıb, I did some testing and discovered that KPI’s work against folders with meta data in the same way that they work against documents or list items. I proved it out by creating a new content type based on the folder content type and then added a few fields. I created some indicators and proved to myself that KPIs work as expected. This was welcome news. It’s not perfect, because the drill-down you get from the KPI against the folders is not exactly what you want. This isn’t too much a drawback in my case because 1) sonunda istifadəçilər hər hansı bir daha bilmirəm 2) the drill-down goes to a folder. They click the folder name and they are at the item. It’s two clicks instead of one, Dünya sonu deyil.

This flowed nicely with the work I was doing. I am creating a folder for every document that gets uploaded. This is done via an event receiver. Nəticəsində, onu saxlamaq üçün tort bir parça var ana qovluq nin meta data in sync with the KPI-driven meta data from the file itself since the plumbing is already in place. This allows me to have my KPI’s and eat them too 🙂

I modified the event receiver to add the folder and then set this new folder’s content type to my custom KPI-friendly content type. This bit of code did the trick:

 SPFolderCollection srcFolders = targetWeb.GetFolder("Documents").Alt;
  SPFolder addedFolder = srcFolders.Add(properties.ListItem.ID.ToString());
  SPContentTypeId kpiCT = yeni SPContentTypeId("0x0120002A666CAA9176DC4AA8CBAA9DC6B4039F");
  addedFolder.Item["Content Type ID"] = KpiCT;
  addedFolder.Item.Update();

Faktiki məzmun Tipi ID tapmaq üçün, Mən kimi haqqinda ayarlarınızı və surəti vasitəsilə məzmun növü / URL onu yapışdırılır ki, əldə:

image

</son>

Blog abunə!

Technorati Tags: ,

Tez və asan: Bir hadisə Alıcı bir SPListItem və SPFolder almaq

Mən bunu qəbul nifrət, but I struggled with this one all day. My event receiver needs to update a field of its parent folder. This little bit shows how to do it:

xüsusi ləğv UpdateParentFolder(SPItemEventProperties xassələri)
{

SPFolder thisItemFolder = properties.ListItem.File.ParentFolder;
thisItemFolder.Item["ZZ Approval Status"] = "Good news, hamı!";
thisItemFolder.Item.Update();


} // UpdateParentFolder

Bu halda, Mən bir sənəd kitabxana ilə çalışıram və xüsusiyyətləri bir ItemAdded hadisə gelen.

Bu oyun Öğeyi özü birbaşa maddəsinin SPFolder ala bilmir ki, (i.e. properties.ListItem.Folder null deyil). Əvəzində, siyahısını öğenin bağlı Fayl gedin ve Fayl qovluğunu almaq.

</son>

Blog abunə!

Technorati Tags:

Lakin başqa bir hadisə Alıcı debug Trick

I’m sure I’m not the first person to come up with this. Lakin, I haven’t noticed anyone publish a trick like this since I started paying close attention to the community last July. Belə, Mən bu sürətli və asan debug tip göndərmək istədiyiniz fikir.

Mən bu səhv yaratmaq üçün açılmış bir hadisə alıcı üzərində çalışıram 12 arı şanı:

Xyzzy hata yüklənməsi və çalışan hadisə qəbuledici Conchango.xyzzyEventReceiver, Version = 1.0.0.0, Mədəniyyət = neytral, PublicKeyToken = blahbalhbalh. Additional information is below. : Obyekt istinad obyekti bir instansiya müəyyən deyil.

I didn’t know where I had introduced this bug because I had done too many things in one of my code/deploy/test cycles.

Mən cəhd Bu həll ümidlər var mənim pdb almaq üçün SharePoint nin 12 Hive bu yığını iz göstərir ki,, but no luck. I don’t know if it’s possible and if someone does, lütfen 🙂

Mən bunu mümkün bilirik üçün öz Giriş mesaj yazmaq 12 arı şanı. Frankly, Mən həyata keçirmək üçün bir az daha az qorxu və tez bir şey istədilər.

Mən ən azı bu kimi ümumi istisna tutmaq və yenidən atma bəzi əsas iz məlumat ala bilər ki, mənə baş:

  cəhd {
    UpdateEditionDate(xassələri);
  }
  tutmaq (Istisna və)
  {
    atmaq yeni Istisna("Dispatcher, UpdateEditionDate(): Istisna: [" + e.ToString() + "].");
  }

Bu qədər göstərdi 12 Hive thusly:

Xyzzy hata yüklənməsi və çalışan hadisə qəbuledici Conchango.xyzzyEventReceiver, Version = 1.0.0.0, Mədəniyyət = neytral, PublicKeyToken = blahblahblah. Additional information is below. : Dispetçer, UpdateEditionDate(): Istisna: [System.NullReferenceException: Obyekt istinad obyekti bir instansiya müəyyən deyil. at Conchango.xyzzyManagementEventReceiver.UpdateEditionDate(SPItemEventProperties xassələri) at Conchango.xyzzyManagementEventReceiver.Dispatcher(SPItemEventProperties xassələri, Simli eventDescription)].

Ki, mənə xüsusi problem aşağı izlemek üçün lazım olan bütün təfərrüatı verdi və mən irəli gedən çox istifadə gözləyirik.

</son>

Blog abunə!

Həll: SPQuery Qovluq Axtar Vermiyor

This past week I was implementing an "evolving" solution for a client that uses BDC and SPQuery and ran into some difficulty using SPQuery against a document library containing folders. Aşağı xətt: assign "recursive" sorğu baxımından özelliğe.

Mənim ssenari:

  • Bazar ertəsi, Mən bir sənəd yüklə və bir meta data təchiz.
  • Aşağıdakı həftə, I upload a new document. Much of this new document’s meta data is based on the document I uploaded on Monday (which we call the "master document").
  • Istifadəçilər asanlıqla bir mövzu axtarış vasitəsilə ki, bazar ertəsi sənəd tapa bilərsiniz, belə ki, biz siyahısına BDC dostu interfeysi təmin edən bir web service fasad yaratdığınız.
  • A BDC data column provides a friendly user interface. (Bu daha çox dostluq Axtarış sütun üçün BDC istifadə edərək, mənim cəhd hissəsidir).

Son BDC fasad xidməti axtarış etmək bu kimi bir sorğu istifadə edir:

 // Bu CAML sorğu yaradan yardım üçün istifadə olunur U2U alət.
      oQuery.Query =
        "<Harada>";

      əgər (titleFilter.Length > 0)
        oQuery.Query   =
          "  <Və>";

      oQuery.Query   =
        "    <Və>" +
        "      <Geq>" +
        "        <FieldRef Name=\"DocumentId\" />" +
        "        <Value Type=\"Text\">" + MinID + "</Dəyər>" +
        "      </Geq>" +
        "      <Leq>" +
        "        <FieldRef Name=\"DocumentId\" />" +
        "        <Value Type=\"Text\">" + maxId + "</Dəyər>" +
        "      </Leq>" +
        "    </Və>";

      əgər (titleFilter.Length > 0)
        oQuery.Query   =
          "    <Ehtiva>" +
          "      <FieldRef Name=\"Title\" />" +
          "      <Value Type=\"Text\">" + titleFilter + "</Dəyər>" +
          "    </Ehtiva>" +
          "  </Və>";
      oQuery.Query   =
        "</Harada>";

Inkişaf ilkin mərhələsində, this worked great. Lakin, biz birdən-birə bəzi problemləri həll etmək üçün dizine qovluq tətbiq, my BDC picker wouldn’t return any results. I tracked this down to the fact that the SPQuery would never return any results. We used folders primarily to allow multiple files with the same name to be uploaded but with different meta data. When the file is uploaded, biz siyahısına maddə şəxsiyyət əsasında bir qovluq yarada və sonra orada faylın köçürülməsi (Mən bu barədə yazırdı burada; biz etdik qarışıq nəticələri bu yanaşma ilə deyil, bütövlükdə, yaxşı çalışır). The user don’t care about folders and in fact, don’t really understand that there are any folders. We have configured all the views on the library to show items without regard to folders.

I hit this problem twice as the technical implementation evolved and solved it differently each time. The first time, I wasn’t using the CONTAINS operator in the query. Without a CONTAINS operator, I was able to solve the problem by specifying the view on the SPQuery’s contructor. Instead of using the default constructor:

SPList oList = web.Lists["Documents"];

SPQuery oQuery = yeni SPQuery();

Mən əvəzinə görünüşü müəyyən bir konstruktor istifadə:

SPList oList = web.Lists["Documents"];

SPQuery oQuery = yeni SPQuery(oList.Views["All Documents"]);

Bu problemi həll edirəm və nəticələr almaq başladı.

I then added the CONTAINS operator into the mix and it broke again. It turns out that the CONTAINS operator, indiyə qədər mən deyə bilərəm ki, bir sadə GEQ kimi məqsədi ilə eyni şəkildə işləmir / LEQ operators. I did some searching and learned that the query’s ViewAttributes should be set to "Recursive", kimi:

oQuery.ViewAttributes = "Scope=\"Recursive\"";

That solved the problem for CONTAINS. Faktiki olaraq, Bu da mənim orijinal axtarış problemi həll və mən recursive atributu ilk dəfə müəyyən etsəydi, Mən məsələ daxil olmazdı.

Bir görünüşü-based SPQuery bəzi operatorlar üçün çalışır ki, (GEQ/LEQ) və başqaları (Ehtiva), ƏĐG qovluq tərkibli sənəd kitabxanalar ilə bütün iş üçün görünmüyor ki, ilə coupled mənə SPQuery bəzi orthogonality məsələlər var iman gətirib.

Xüsusi Thanks:

  • Da yaxşı insanlar U2U və onların sorğu alət.
  • Michael Hoffer böyük "etməklə öyrənmə" blog, Şərh və cavablar.

</son>

Blog abunə!

MOSS KPI bug? Siyahısı Göstərici qovluqları ilə Document Kitabxana bağlıdır

UPDATE 02/29/08: I solved this problem by creating a folder and then assigning a content type to the folder which has the meta data I need for the KPIs. Mən burada bir az daha ətraflı ki, təsvir.

We have implemented a technical solution where users upload documents to a document library. An event receiver creates a directory and moves the file to that directory (Mən nə yazdı bənzər bir texnika istifadə edərək burada). We’ve successfully navigated around the potential issues caused by event receivers that rename uploaded files (mainly because users never start their document by clicking on "New" lakin əvəzinə yerli docs yaratmaq və onlara yüklemek).

The meta data for these documents includes a Yes/No site column called "Urgent" and another site column called "Status". We need to meet a business requirement that shows the percentage of "Urgent" documents whose status is "Pending".

Bunu etmək üçün adətən sadədir Mən SharePoint Beagle çox çox bu kimi bir şey təsvir ekran görüntüleri çox siz istəyirsinizsə ilə.

Xülaseyi-kəlam, Mən aşağıdakı etdi:

  • Create a view on the doc library called "Pending".
  • Qovluq yapısını ignore baxımından yapılandırın.
  • Bir KPI siyahısı yaradın.
  • Create an indicator in the list that points to the doc lib and that "Pending" keçirmək.

This simply does not work. The KPI shows my target (e.g. beş təcili sənədlər) but always shows the actual number of urgent documents as zero. Paradoxically, Siz ətraflı aşağı qazmaq əgər, it shows the five urgent documents in the list. I created a very simple scenario with two documents, one in a folder and one not. Here is the screen shot:

image

The above screen shot clearly shows there are two documents in the view but the "value" is one. The "CamlSchema" with blank document Id is in the root folder and the other is in a folder named "84".

Bu, hətta bir görünüşü müəyyən ki, mənə görünür, the KPI doesn’t honor the "show all items without folders" yaradılması və yerinə, kök qovluğa sınırlar özü.

Mən yanlış Ben əgər, mənə bir xətt düşmək və ya comment tərk edin.

</son>

Blog abunə!

Technorati Tags:

Problem həll: “FileNotFoundException” Mənim Feature qəbuledicisi.

I was working on a feature last week that would add some event receivers to a specific list instance. (Mən burada bu siyahıya alıcı haqqında bir az blogged).

Command line istifadə, Mən heç bir səhv ilə xüsusiyyət quraşdıra bilərdik (ancaq gizli səhv üçün aşağıya baxın). When I tried to deploy the feature on the site, MOSS complained of a "FileNotFoundException" səhv. This blog entry describes how I solved it.

This is the error that MOSS showed me in the web browser:

Feature ‘b2cb42e3-4f0a-4380-aaba-1ef9cd526f20’ could not be installed because the loading of event receiver assembly "xyzzyFeatureReceiver_0" failed: System.IO.FileNotFoundException: Could not load file or assembly ‘xyzzyFeatureReceiver_0’ onun bağımlılıkları və ya bir. The system cannot find the file specified.
File name: ‘xyzzyFeatureReceiver_0’
at System.Reflection.Assembly.nLoad(Fayl AssemblyName, Simli codeBase, Sübut assemblySecurity, Assambleya locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(AssemblyName assemblyRef, Sübut assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(String assemblyString, Sübut assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.Load(String assemblyString)
at Microsoft.SharePoint.Administration.SPFeatureDefinition.get_ReceiverObject()
WRN: Assembly binding logging is turned OFF.
To enable assembly bind failure logging, set the registry value [HKLM\Software\Microsoft\Fusion!EnableLog] (DWORD) üçün 1.
Qeyd: There is some performance penalty associated with assembly bind failure logging.
To turn this feature off, remove the registry value [HKLM\Software\Microsoft\Fusion!EnableLog].

Troubleshoot issues with Windows SharePoint Services.

I know how to deliberately cause that error: don’t install the assembly in the GAC. Lakin, 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% Mən həmişə gacutil səbəbdən mövcud düşündüm, çünki rahat bunu … so I tried that. It made no difference.

Mən Internets axtarış və bu post tapılmadı: http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=2243677&SiteID=1

Plakat kodu eyni kökdən bit istifadə oldu (Bu siyahıda olan Inside WSS kitabından) so that was a hopeful sign. Lakin, bir ilə bəzəyən toplaşmaq təklifi [yığma: ] 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.

Sonrakı, I went to the trouble of enabling the "assembly bind failure log" (following the helpful and accurate instructions provided) 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. Lakin … it won’t search for it in the GAC.

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" for feature b2cb42e3-4f0a-4380-aaba-1ef9cd526f20: System.ArgumentNullException: Dəyər null ola bilməz.
Parametre adı: növü
at System.Activator.CreateInstance(Type type, Boolean nonPublic)
at System.Activator.CreateInstance(Type type)
at Microsoft.SharePoint.Administration.SPFeatureDefinition.get_ReceiverObject()

Troubleshoot issues with Windows SharePoint Services.

Time for one last trip to the Internets!

This time I find out, predictably enough, that MOSS issues this error because the assembly is not in GAC.

I want to get something positive out of this and try to feel a little proud that I’ve created the Fugitive of MSIL assemblies, but it’s not working. I’m just plain annoyed. I find myself muttering "chicken or the egg" under my breath.

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" but can’t find one).

I install the feature and activate it and … it works! Belə, after all that, I had to basically ‘reboot’ my project. This is another reason why I hate computers.

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. Nədənsə, I did not use the -force option when I installed the new project. Bu dəfə, I did actually, truly forget to copy this new project’s assembly into the GAC. Nəticəsində, I received that "FielNotFoundException" səhv. Bu dəfə, Mən stsadm onu ​​əldə, not when I tried to activate the feature via the web browser. Belə, -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.

</son>

Sürətli & Asan: Bugün üçün hadisə Alıcı Via SharePoint Object Model istifadə Uploaded File Rename

UPDATE: This works but there are significant limitations which are described in the comments. This may still be useful in some cirumstances.

UPDATE 2: Mənim cari layihə, users always upload documents. Nəticəsində, 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() alıcı əslində adını dəyişmək həyata əvvəl və o vaxtdan bəri orada düzgün değer axtarır, 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()" üsul. Əvəzində, Biz istifadə "MoveTo(…)". Here is a minimal bit of code to accomplish this:

 ictimai alıqlamaq ləğv ItemAdded(SPItemEventProperties xassələri)
        {
            SPFile f = properties.ListItem.File;

            f.MoveTo(properties.ListItem.ParentList.RootFolder.Url + "/xyzzy.doc");
            f.Update();

        }

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.

Bu, eyni şey ki, daha faydalı versiyası, but assigns the name of the file to "Title":

 ictimai alıqlamaq ləğv ItemAdded(SPItemEventProperties xassələri)
        {
            DisableEventFiring();

            // Fayl özü adı ilə bu bəndin adı Təyin.
 // QEYD: Biz fayl özü dəyişdirmək əvvəl təyin yer almalıdır.
 // Yeniləmə Calling() ki, SPFile üzrə xüsusiyyətlərini etibarsız görünür
 // müəyyən mənada.  Updates to "Title" dəyişiklik qədər uğursuz (və yeniləmə() çağırmaq)
 // fayl adı dəyişikliyin qarşısında köçürülüb.
            properties.ListItem["Title"] = Properties.ListItem.File.Name;

            properties.ListItem.Update();

            SPFile f = properties.ListItem.File;

            // Fayl uzadılması alın.  Biz sonra ehtiyac.
 sim spfileExt = yeni Fayl haqqında məlumat(f.Name).Artırma;

            // Siyahısı maddənin ID fayl adını dəyişmək və saxlamaq üçün fayl uzantısı istifadə
 // vuruşa onun bir hissəsi.
            f.MoveTo(properties.ListItem.ParentList.RootFolder.Url +
                "/" + properties.ListItem["ID"] + spfileExt);

            // Hərəkət törətmək.
            f.Update();

            EnableEventFiring();
        }

Sadə Tip: Məqalələr Query Web Part, Sütun dəyəri və XSL Axtarış

I have a column name in a content type named "Real Estate Location".

That column is of type "lookup".

Mən redaktə var <CommonViewFields> və ItemStyle.xsl sütun göstərmək.

A sadə <XSL:= seçin dəyər və…> geri sıra mövqe data ehtiva daxili dəyər qaytarır, kimi:

1;#Mayami

Insan dostu dəyər əldə etmək üçün, substring-sonra XSL istifadə, kimi:

<XSL:value-of select="substring-after(@ Real_x005F_x0020_Estate_x005F_x0020_Location,'#')"></XSL:dəyər və>

Use this technique whenever you are working with lookup values in XSL transforms and need to get the human-friendly value.

<Tamamlama />

Technorati Tags: , ,

Tez və asan: Site Sütun Daxili Sütun adı müəyyən

UPDATE: Jeremy Thake Bu barədə blogged və bir qədər qoymuşdur bir konsol tətbiqi üçün kod daxili adları göstərir ki,.

I was trying to get a content query web part to display a due date from a task and because the screen label is "Due Date", Mən sütun adını istifadə etmək güman <CommonViewFields> is "Due_x0020_Date".

Yanlış!

The real column name in this case was "DueDate".

Nasıl almısan? I re-read Heather CQWP değiştirmeyle haqqında Süleymanın blog giriş to show additional columns of data. She describes this process at step #13. Trust it. It’s correct. At least, it was correct for me. I did not trust it at first for another column with a much longer name.

I say "Trust it" because I did not trust it and probably wasted near two hours butting my head up against a wall. After I resolved the "DueDate" ad, Mən başqa sahədə əlavə etmək istədi <CommonViewFields>. Using the Solomon technique, I was getting a column name like "XYZ_x0020_Project_x0020_Due_x00".

Özümə düşündüm, that’s clearly a truncated name. I went ahead and un-truncated it with no success. I finally used the seemingly truncated name and it worked.

Bonus ipucu: Mən CQWP ilə iş zaman, Mən pis bir daxili adı eklendiğinde <CommonViewFields>, the CQWP would tell me that the query had returned no results. Lakin, Mən sahədə adı bir veri növü eklendiğinde, it would return a result. Adding the data type actually masked a problem since I was referencing a non-existent field. I could add it, amma onun dəyəri keçirmək üçün cəhd zaman, I would always get a blank.

Bu səhv maska ​​etməyib:

<CommonViewFields>Due_x0020_Date;</CommonViewfields>

Bu səhv maska ​​idi:

<CommonViewFields>Due_x0020_Date,DateTime;</CommonViewfields>

</son>